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1.0 INTRODUCTION 

The 33C92A is a MOS/VLSI device which is im- 
plemented in Western Digital's CMOS process. It 
operates from a single 5 volt supply and is avail- 
able in either a 44-pin chip carrier or a 48-pin 
dual-in-line package. All inputs and outputs are 
TTL-compatible. 



1.1 FEATURES 

• Implements full SCSI bus features: arbitration, 
disconnect, reconnect, parity 
generation/checking on both data ports, 

soft reset, and synchronous data transfers. 

• Synchronous offset selectable from 1 to 12. 
bytes, with selectable transfer period up to 5 
Mbytes/s. ANSI spec compatibility guaranteed 
to 4 Mbytes/s. 

• Compatible with most microprocessors through 
an 8-bit data bus; supports both multiplexed 
and non-multiplexed address/data bus 
systems. Host bus data parity checking and 
generation is an optional feature. 



• Can be used as host adapter (SCSI Initiator) or 
peripheral adapter (SCSI Target). 

• Data transfer options include programmed I/O, 
single-byte DMA, burst (multibyte) DMA, or 
direct bus access (WD bus) transfers. 

• Burst data transfers up to 4096 bytes. 

• Programmable timeout for selection and 
reselection. 

• "Combination" commands greatly reduce 
interrupt-handling responsibilities. 

• Special "Translate Address" command 
performs the Logical-to-Physical address 
translation. 

• Single +5V supply. 

• Available in 44-pin chip carrier or 48-pin DIP. 

• Low-power CMOS design. 

• Compatible with single-ended or differential 
external drivers. 
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2.0 DESCRIPTION 

The 33C92A is Intended for use in systems which 
interface to the SCSI (Small Computer System 
Interface) Bus. The 33C92A can operate in both 
the initiator (typically, a host computer system) 
and the target (typically, a peripheral device) SCSI 
bus roles. 

When used in the host system, the 33C92A inter- 
faces to both the host bus and the SCSI bus. To 
perform a SCSI operation, the host processor 
must issue a command to the 33C92A to select 
the desired Target. The 33C92A then arbitrates for 
the SCSI bus and selects the peripheral unit. If it 
fails to get the bus because of a device with 
higher priority, it continues trying, notifying the 
host when it has succeeded by generating an 
interrupt. At this point, the 33C92A is operating in 
the initiator role. When the peripheral requests a 
SCSI command from the host, the 33C92A 
receives the request and generates another 
interrupt to the host. The host responds to this 
interrupt by issuing a "Transfer Info" command 
and supplying SCSI command bytes to the 
33C92A. The 33C92A transfers the SCSI com- 
mand to the peripheral, and then waits for the 



next bus phase request. This process continues 
until all SCSI information including data, 
status, and messages have been transferred. 

The 33C92A also offers high-level Select-and- 
Transfer commands, eliminating the interrupt han- 
dling otherwise required between each SCSI bus 
phase. 

When the 33C92A is used in a peripheral system, 
it interfaces with a local processor and the SCSI 
bus just as it does when used as a host adapter. 
In this environment, the 33C92A will operate 
primarily in a Target role. The Target-role com- 
mand set enables the 33C92A to request each 
SCSI bus phase individually or to sequence the 
SCSI bus phases automatically through the use of 
combination commands. 

The 33C92A has an internal microcontroller, a 
register task file, and SCSI interface logic. This 
architecture supports both tight control of the 
protocol for non-standard SCSI implementations, 
as well as a hands-free mode for standard SCSI 
applications. 
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3.0 33C92A PINOUT 





SO '2 co co co co co co coco 

nnnnnnnnnnn 




i/6 [~ 


39 38 
40 


37 36 35 34 33 32 31 30 29 

28 


Zl SDP 


REQ £Z 


41 


27 


ZlRE 


ACK LZ 


42 


26 


Zl WE 


ATN LZ 


43 


25 


Zl cs 


Vcc LZ 
TGS LZ 


44 
1# 


24 

WD33C92A 


Zl AO 
Zl Vss 


IGS LZ 


2 


22 


Z1D7 


SDIE LZ 


3 


21 


Zl D6 


SDOE LZ 


4 


20 


Zl D5 


ARBLD C 


5 


19 


Zl D4 


CLK LZ 


6 


18 


Z3 °3 




V 8 


9 10 11 12 13 14 15 16 17 




uuuuuuuuuuu 

OOvj LJ OI^0 0rW 
>->cowd^ ^ QC,Q 
w 4! m w < Q < H 





FIGURE 3-1. 44-PIN QUAD PIN DIAGRAM 
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FIGURE 3-2. 48-PIN DIP PIN DIAGRAM 
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4.0 SIGNAL DESCRIPTIONS 



PIN 


MNEMONIC 


I/O 


DESCRIPTION 


6 


CLK 


I 


8-20 MHz square wave clock. 


37 


MR- 


I 


Reset is an active-low input which forces the 33C92A into an idle 
state. All SCSI outputs are tristated. 


14 


INTRQ 





Interrupt Request to external microprocessor. Indicates command 
completion/termination or a need to service the SCSI interface. 
This bit is reset when the SCSI STATUS register is read. 


27 


RE- 


I/O 


Read enable is an active-low input which is used with CS- to read 
a register. In WD Bus mode, it is used as an output to read data 
from a sector buffer. Also used for DMA transfers. (TRI-STATE) 


26 


WE- 


I/O 


Write enable is an active-low input which is used with CS- to write 
a register. In WD Bus mode, it is used as an output to write data to 
a sector buffer. Also used for DMA transfers. (TRI-STATE) 


25 


CS- 


I 


Chip Select is an active-low input which qualifies RE- and WE- 
when accessing a register. This signal must be inactive during a 
DMA cycle (DACK- active in DMA/burst mode or DRQ active in 
WD Bus mode). 


24 


A0 


I 


Address pin used to access the internal registers for non-multi- 
plexed address/data busses (i.e. the ALE pin is grounded). The ad- 
dress of the desired register is loaded into the ADDRESS register 
during a write cycle with A0=0. The selected register is then ac- 
cessed when A0=1 . 


11 


ALE 


I 


Address Latch Enable is used for multiplexed address/data bus- 
ses to load the address of the desired 33C92A register from the 
data bus. If indirect addressing is to be used, the ALE pin should 
be grounded. See the description of the ADDRESS register for a 
complete discussion of direct and indirect addressing. 


13 


DACK- 
(RCS-) 


I/O 


DMA acknowledge input used for interfacing to an external DMA 
controller (e.g. 8237). When DACK- is low, all bus transfers are 
to/from the DATA register regardless of the contents of the AD- 
DRESS register. In WD Bus mode, this pin functions as a RAM 
chip select output to allow the 33C92A to access a sector buffer. 
RE- and WE- are outputs when RCS- is active. Since this pin can 
be an open drain output, a pullup resistor may be required when 
operating in WD Bus mode. 



TABLE 4-1. PROCESSOR/DMA INTERFACE 



NOTE: 

Pin numbers are for the 44-pin quad package. 
See Figure 3-2 for the 48-pin positions. 
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PIN 


MNEMONIC 


I/O 


DESCRIPTION 


12 


DRQ- 


I/O 


Data request Is an output when Interfacing to (DRQ) an external 
DMA controller and an input when in WD Bus mode. When used 
with an external DMA controller, DRQ- and DACK- form the hand- 
shake for the data-byte transfers. In Burst mode, DRQ- remains 
low as long as there is data to transfer. In WD Bus mode, the 
33C92A performs burst transfers while DRQ is high, and when 
DRQ is low, data transfers are inhibited, RCS- is false, and the RE- 
and WE- outputs are disabled. Since this pin can be an open drain 
output, a pullup resistor may be required when operating in DMA 
or Burst mode. 


15-22 


D7-D0 


I/O 


Processor data bus. 


28 


DP 


I/O 


Data Parity, used only for checking/generating parity during data 
transfers. 



TABLE 4-1. PROCESSOR/DMA INTERFACE (CONTINUED) 




NOTE: 

Pin numbers are for the 44-pin quad package. 
See Figure 3-2 for the 48-pin positions. 



a 
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PIN 


MNEMONIC 


I/O 


DESCRIPTION 


43 


ATN 


I/O 


ATN Is an output in the initiator role and an input in the target role. 
It is used to indicate the ATTENTION condition. 


41 


REQ 


I/O 


REQ is an input in the initiator role and an output in the target role. 
It indicates a request for a REQ/ACK data transfer. 


42 


ACK 


I//0 


ACK is an output in the initiator role and an input in the target role. 
It indicates an acknowledgement for a REQ/ACK data transfer 
handshake. 


39 


MSG 


I/O 


MSG is an input in the initiator role and an output in the target role. 
It is asserted during a MESSAGE phase. 


38 


C/D- 


I/O 


C/D- is an input in the initiator role and an output in the target role. 
It is used to indicate whether CONTROL or DATA information is on 
the SCSI data bus. 


40 


l/O- 


I/O 


I/O- is an input in the initiator role and an output in the target role. 
It controls the direction of data movement on the SCSI data bus 
with respect to an Initiator. 


29-36 


SD7 
I SDO 


I/O 


SCSI data bus. 


28 


SDP 


I/O 


SCSI data bus parity signal. 


9 


BSYI 


I 


BSYI signals the 33C92A that SCSI BSY- is asserted. 


7 


BSYO 





The 33C92A asserts BSYO to assert the SCSI BSY- signal. 


10 


SELI 


I 


SELI signals the 33C92Athat SCSI SEL- is asserted. 


8 


SELO 





The 33C92A asserts SELO to assert the SCSI SEL-signal. 


3 


SDIE 





Enables SCSI data bus receivers. 


4 


SDOE 





Enables SCSI data bus drivers. 


5 


ARBLD 





Latches the decoded port number into an external register just 
prior to the SCSI bus arbitration process. 


2 


IGS 





The 33C92A asserts IGS when operating as an Initiator. IGS 
enables the SCSI drivers for ATN and ACK. 


1 


TGS 





The 33C92A asserts TGS when operating as a Target.TGS 
enables the SCSI drivers for REQ, MSG, C/D- and I/O-. 



TABLE 4-2. SCSI INTERFACE 



NOTE: 

Pin numbers are for the 44-pin quad package. 
See Figure 3-2 for the 48-pin positions. 
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5.0 33C92A BLOCK DIAGRAM 
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FIGURE 5-1. 33C92A BLOCK DIAGRAM 
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6.0 33C92A REGISTERS 

6.1 REGISTER MAP 



A0 


R/W 


REGISTER ACCESSED 


ADDRESS 
(HEX) 





R 


AUXILIARY STATUS REGISTER 


XX 





W 


ADDRESS REGISTER 


XX 




R/W 


OWN ID REGISTER /CDB SIZE 00 


00 




R/W 


CONTROL REGISTER 


01 




R/W 


TIMEOUT PERIOD REGISTER 


02 




R/W 


TOTAL SECTORS REGISTER /CDB 1ST 


03 




R/W 


TOTAL HEADS REGISTER /CDB 2ND 


04 




R/W 


TOTAL CYLINDERS REGISTER(MSB)/CDB 3RD 


05 




R/W 


TOTAL CYLINDERS REGISTER(LSB)/CDB 4TH 


06 




R/W 


LOGICAL ADDRESS(MSB) /CDB 5TH 


07 




R/W 


LOGICAL ADDRESS(2ND) /CDB 6TH 


08 




R/W 


LOGICAL ADDRESS(3RD) /CDB 7TH 


09 




R/W 


LOGICAL ADDRESS(LSB) /CDB 8TH 


0A 




R/W 


SECTOR NUMBER REGISTER /CDB 9TH 


0B 




R/W 


HEAD NUMBER REGISTER /CDB 1 0TH 


OC 




R/W 


CYLINDER NUMBER(MSB) REGISTER/CDB 11TH 


0D 




R/W 


CYLINDER NUMBER(LSB) REGISTER/CDB 12TH 


0E 




R/W 


TARGET LUN REGISTER 


OF 




R/W 


COMMAND PHASE REGISTER 


10 




R/W 


SYNCHRONOUS TRANSFER REGISTER 


11 




R/W 


TRANSFER COUNT REGISTER (MSB) 


12 




R/W 


TRANSFER COUNT REGISTER (2ND BYTE) 


13 




R/W 


TRANSFER COUNT REGISTER (LSB) 


14 




R/W 


DESTINATION ID REGISTER 


15 




R/W 


SOURCE ID REGISTER 


16 




R 


SCSI STATUS REGISTER 


17 




R/W 


COMMAND REGISTER 


18 




R/W 


DATA REGISTER 


19 



NOTES: 

1. All unused bits of a defined register are 
reserved and must be zero. 

2. Reading an undefined or unavailable register 
results in an all-ones data bus output. 

3. Register addresses are determined by the AD- 
DRESS register bits AR7 through AR0. 



4. When using a multiplexed address/data bus 
with ALE, the A0 pin is ignored and the ADDRESS 
register is loaded with ALE. In this mode, the 
AUXILIARY STATUS register is mapped at hex 
1F. 

5. See section 6.3 for a description of how reset 
affects the internal registers. 



22-8 



11/19/91 



33C92A REGISTERS 



WD33C92A 



6.2 REGISTER DESCRIPTIONS 

6.2.1 Auxiliary Status Register 

The AUXILIARY STATUS register is a read-only 
register which contains general status information 
not directly associated with the interrupt condition. 
The AUXILIARY STATUS register may be ac- 
cessed at any time, except during DMA accesses 
(DACK- asserted in DMA/Burst mode or DRQ as- 
serted in WD bus mode). 



7 


6 


5 


4 


3 


2 


1 





INT 


LCI 


BSY 


CIP 








PE 


DBR 



Bit DBR-DATA BUFFER READY 

DATA BUFFER READY is used during 
programmed I/O to indicate to the proces- 
sor whether or not the DATA register is 
available for reading or writing. During 
Send or Transfer commands which trans- 
mit data over the SCSI bus, the DBR bit is 
set when the 33C92A is ready to take a 
byte from the host; the bit is reset when 
the processor writes the byte to the DATA 
register. During Receive or Transfer com- 
mands which receive data over the SCSI 
bus, the DBR is set when a byte is 
received; it is reset when the processor 
reads the byte from the DATA register. 

Bit 1 PE-PARITY ERROR 

PARITY ERROR status indicates that 
even parity was detected on a data byte 
received during an information transfer. 
Parity is checked on data received from 
the host bus during transfers out to the 
SCSI bus and is checked on data received 
from the SCSI bus during transfers out to 
the host bus. 

Detection of a parity error will set the PE 
status bit regardless of the state of the 
HHP or HSP bits in the CONTROL 
register. The PE bit is cleared when a new 
command is issued. 

Bit 2,3 Not Used 

Not used bits are zero. 



Bit 4 CIP-COMMAND IN PROGRESS 

COMMAND IN PROGRESS, when set, in- 
dicates that the 33C92A is interpreting the 
last command entered into the COM- 
MAND register and therefore this register 
is unavailable. When this bit is reset, a 
command may be written to the COM- 
MAND register. 

Bit 5 BSY-BUSY 

BUSY indicates that a Level II command 
is currently executing and therefore only 
the COMMAND register (when CIP = 0), 
the DATA register, and the AUXILIARY 
STATUS register are accessible by the 
host. A Level II command may not be writ- 
ten to the COMMAND register when this 
bit is one. 

Bit 6 LCI-LAST COMMAND IGNORED 

LAST COMMAND IGNORED indicates 
that a command was issued by the host 
just prior to or concurrent with a pending 
interrupt, and therefore the command will 
be ignored. 

Bit 7 INT-INTERRUPT PENDING 

INTERRUPT PENDING indicates that the 
INTRO pin is asserted. The host should 
read the SCSI STATUS register to clear 
INTRO prior to issuing any commands. 



6.2.2 Address Register 

The ADDRESS register is a write-only register 
which contains the address of the register to be 
accessed. Registers in the 33C92A may be ac- 
cessed in one of two ways: 



Direct addressing (multiplexed address/data 
busses). In direct addressing, the falling edge 
of the ALE signal is used to latch the address 
into the ADDRESS register. The A0 pin should 
be connected to ground when using this 
method. The ALE is typically then followed by 
the CS- and WE- or RE- signals that access 
the selected register. Also, in direct 
addressing, the AUXILIARY STATUS register is 
located at address 1 F hex. 
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Indirect addressing (separate address/data 
busses). In indirect addressing, the register 
access is performed in two separate cycles. 
This method is enabled by attaching ALE to 
ground. First, the ADDRESS register is loaded 
by performing a write of the desired address to 
the 33C92A (WE- and CS- asserted) with 
A0=0. Then the register is accessed by 
asserting CS- and WE- or RE-, with A0=1 . 
Also, following every access with A0=1 , the 
ADDRESS register will automatically increment 
to point at the next register, with the exception 
of the following locations: AUXILIARY STATUS 
register, DATA register, and the COMMAND 
register. In indirect addressing, the AUXILIARY 
STATUS register is accessed by performing a 
read (CS- and RE- asserted) with A0=0. 



6.2.3 Own ID/CDB Size Register 

The OWN ID/CDB SIZE register, in its first mode, 
contains both the encoded ID of the 33C92A on 
the SCSI bus and several control bits that are 
used to initially configure the device during the 
"Reset" command. These bits control 'advanced 
feature' selection, host bus parity enable, and 
selection of the divisor for the input clock. In its 
second mode (when advanced features are 
enabled, see 7.3), this register is used during the 
combination commands to specify the SCSI CDB 
size if the command group is unknown to the 
33C92A. 

In the first mode, this register (as defined below) 
is sampled and becomes effective only after a 
"Reset" command is issued to the device. This 
register must be initialized, and a "Reset" com- 
mand must then be issued, following a hardware 
reset to set the SCSI bus ID, the clock divisor, and 
the operating modes before any other commands 
are issued. 

In the second mode, bits 3-0 of this register are 
used during the Select-and-Transfer and Wait-for- 
Select commands to specify the SCSI Command 
Descriptor Block size if it is not a group 0, group 
1, or group 5 command. This mode is enabled 
only when advanced features are enabled (see 
7.3). 
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Bit 0-2 IDn-SCSI ID Bits 0-2 

SCSI ID Bits 0-2 set the SCSI bus ID 
number that the 33C92A will use during 
arbitration and selection. 

Bit 3 EAF-ENABLE ADVANCED FEATURES 

ENABLE ADVANCED FEATURES, when 
set to one, causes the 33C92A to enable 
certain advanced features (see section 
7.3). When this bit is zero, those features 
are disabled. 

Bit 4 EHP-ENABLE HOST PARITY 

ENABLE HOST PARITY, when set to one, 
enables odd parity checking on the host 
bus; the PE bit in the AUXILIARY STATUS 
register will indicate parity errors detected 
on the host bus, and the HHP bit in the 
CONTROL register will be used. When 
this bit is zero, no checking is performed 
on the host bus; the PE bit is not set when 
a parity error is detected on the host bus, 
and the HHP bit must be set to zero. 
NOTE: Parity is always generated on the 
host data parity bit (DP), regardless of the 
state of this bit. 

Bit 5 Not Used 

Not used bits are zero. 

Bit 6-7 FSn-FREQUENCY SELECT 0-1 

FREQUENCY SELECT 0-1 select the 
divisor that is applied to the input clock. 
The resulting clock is used for data trans- 
fer timing and for SCSI bus arbitration 
timing. The table below shows input clock 
frequency ranges and the corresponding 
divisors. The correct divisor for the input 
clock must be used, or SCSI bus timing 
specifications may not be met. 
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INPUT 

CLOCK 

FREQUENCY 

(MHZ) 


FS1 


FSO 


RESULTING 
DIVISOR 


8-10 








2 


12-15 





1 


3 


16-20 


1 





4 


XX 


1 


1 


undefined 



Note that an 11 MHZ clock rate should not be 
used, as the resulting SCSI bus clear delay may 
violate SCSI specifications. The formula for com- 
puting the maximum SCSI data transfer rate is: 



MAXIMUM SCSI TRANSFER RATE = 

INPUT CLOCK FREQUENCY/CLOCK DIVISOR[MByte/sec] 



6.2.4 Control Register 

The CONTROL register is used to enable/disable 
certain functions, such as response to parity er- 
rors and the SCSI attention condition, interrupt 
handling, and data transfer modes. 
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Bit HSP-HALT on SCSI PARITY ERROR 

The HALT on SCSI PARITY ERROR bit 
enables the 33C92A to immediately ter- 
minate a Receive or Transfer command if 
a parity error is detected on an incoming 
SCSI data byte. In the Initiator role, ter- 
mination due to a SCSI parity error causes 
the ACK pin to be left in the active state in 
order to inhibit any additional data trans- 
fers (REQs) by the Target; this facilitates 
error handling with the Target. 
Synchronous data transfers check 
parity every 4096 bytes, or at the end of 
the remaining transfer count, whichever is 
less. Asynchronous transfers check parity 
on every byte. 

Bit 1 HA-HALT on ATTENTION 

The HALT on ATTENTION bit (in Target 
mode only) enables the 33C92A to ter- 
minate a Send or Receive command if the 
ATN input is asserted. This normally indi- 



cates that the Initiator detected a parity 
error while receiving data from the 
33C92A. The ATN input is tested before 
the start of a data transfer, every 4096 
bytes if the transfer count is greater than 
4096, and after the end of the transfer. 
These rules apply to bothsynchronous and 
asynchronous transfers. 

Bit 2 ^-INTERMEDIATE DISCONNECT 
INTERRUPT 

The INTERMEDIATE DISCONNECT IN- 
TERRUPT bit, when set, enables the 
33C92A to generate an 85H interrupt and 
complete a Select-and-Transfer command 
if the Target disconnects according to the 
defined SCSI protocol. When this bit is 
reset, no interrupt is generated 
by a valid disconnect. This feature, when 
used with the Resume SAT command, 
provides support for overlapped SCSI 
operations. ID! is also used to select ex- 
ecution options in Target mode Combina- 
tion commands that serve to reduce host 
system overhead. Refer to Section 7 for 
more details. 

Bit 3 EDI-ENDING DISCONNECT INTERRUPT 

When the ENDING DISCONNECT IN- 
TERRUPT bit is set, the 16H interrupt 
which normally follows the COMMAND 
COMPLETE message during the 
execution of a Select-and-Transfer com- 
mand will be suppressed until the Target 
disconnects from the SCSI bus. EDI is 
also used in the Target mode Combination 
commands to enable chaining between 
those commands, resulting in reduced 
host system overhead. Refer to Section 7 
for more details. 

Bit 4 HHP-HALT on HOST PARITY ERROR 

The HALT on HOST PARITY ERROR bit 
enables the 33C92A to immediately ter- 
minate a Send or Transfer command if a 
parity error is detected on an incoming 
host data byte. Host parity errors are 
checked according to the rules for check- 
ing SCSI parity errors. However, a halt on 
a host parity error will not hold the ACK 
signal asserted when an error occurs. 
Host parity checking is performed at the 
same intervals as SCSI parity checking. 
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Bit 5-7 DMx-DMA MODE SELECT 

DMA MODE SELECT bits 2-0 are used to 
select the DMA mode of operation, which 
describes the host bus transfer mode 
used during Data In or Data Out phases. 
The following table describes the different 
DMA modes, and the state of these bits to 
select them: 



DM2 


DM1 


DM0 


DMA MODE SELECTED 











POLLED MODE, or no DMA enabled. All data phase transfers are per- 
formed by polling for DBR in the AUXILIARY STATUS register, and 
then writing (reading) the data to (from) the DATA register. 








1 


BURST MODE selects a demand-mode DMA interface. In this mode, 

the DRQ- signal will be active as long as there is data/space 

in the internal FIFO to allow the transfer to continue. The DMA controller 

responds by asserting DACK- and RE-/WE- as long as DRQ- 

is active. 





1 





WD-BUS MODE is selected when the 33C92A is connected to a WD 
Bus. This mode also can be called Direct Buffer Access (DBA) mode. In 
this mode, the 33C92A acts as a bus master, and all data access signals 
reverse their direction: The DRQ- output signal becomes the DRQ input, 
which enables the 33C92A to drive the buffer bus control signals. The 
DACK- output signal becomes the RCS- input, which is asserted as a 
chip select for the buffer. The RE- and WE- inputs become outputs which 
drive the read and write functions of the RAM buffer. As long as the 
DRQ signal is asserted, transfers will continue in a burst manner, until 
the transfer is complete or the decides to pause the transfer by negating 
the DRQ signal; one more transfer may occur after this transition, and 
then the DACK-, RE-, and WE- signals are negated. 


1 








DMA MODE is selected when the 33C92A is to be used with a DMA con- 
troller in single-byte transfer mode. In this mode, DRQ- is asserted and 
then negated, and the DMA controller responds by asserting DACK- 
and WE- or RE-, for each data byte transferred to/from the 33C92A. 



TABLE 6-1. DMA MODE SELECTED 



6.2.5 Timeout Period Register 

The TIMEOUT PERIOD register is an 8-bit 
register containinga preset value which deter- 
mines the timeout period for Select and 
Reselect commands. This value may be calcu- 
lated as a function of the input clock frequency 
and the desired timeout period, as shown in the 
following equation: 

register value = Tper * Ficlk/80 



Where: 

Tper = the desired timeout period in milliseconds 

Ficlk = the input clock frequency at the MCK pin in 
Megahertz (with no divisor applied). 

The constant '80' scales the units of the equation, 
as is based on the internal timeout cycle time. 
The user should round the resulting 'register 
value' up to the next integral value to ensure that 
the user's minimum timeout requirement is met. 
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The timeout period specifies how long the 
33C92A will wait for a response (indicated by 
assertion of the BSY- signal) after it has begun 
the selection phase (assert SEL- and negate 
BSY-) before terminating the command. The 
timeout function can be disabled by loading the 
TIMEOUT PERIOD register with zero. 

The following twelve registers are used exclusive- 
ly by the Translate Address and/or "combination" 
commands. The function of each register is deter- 
mined by the type of command issued. 



6.2.6 Total Sectors Register/CDB 1st Byte 

Translate Address: 

The TOTAL SECTORS register should be set 
to the total number of sectors per track prior to 
issuing a Translate Address command. 

Select-and-Transfer: 

This register should be loaded with the first 
byte of the COMMAND DESCRIPTOR 
BLOCK before issuing a Select-and-Transfer 
command. 

Wait-for-Select-and-Receive: 

The 33C92A will store the first byte of the 
received CDB in this register. 



Select-and-Transfer: 

This register should be loaded with the 
third and fourth bytes of the CDB before issu- 
ing a Select-and-Transfer command. 

Wait-for-Select-and-Receive: 

The 33C92A will store the third and fourth 
bytes of the received CDB in this register. 



6.2.9 Logical Address Register/CDB 5th-8th 
Bytes 

Translate Address: 

The LOGICAL ADDRESS register is a 32-bit 
register which should be loaded with the logi- 
cal address to be translated prior to issuing 
the Translate Address command. 

Select-and-Transfer: 

For six byte CDBs, only the first two bytes of 
this register are loaded with the fifth and sixth 
bytes of the CDB. For ten and twelve byte 
CDBs, this register is loaded with the fifth, 
sixth, seventh, and eighth bytes of the CDB. 

Wait-for-Select-and-Receive : 

The 33C92A will store the fifth, sixth, seventh 
(if any), and eighth (if any) bytes of the 
received CDB in this register. 




6.2.7 Total Heads Register/CDB 2nd Byte 

Translate Address: 

This register holds the total number of 
heads during a Translate Address command. 

Select-and-Transfer: 

This register should be loaded with the 
second byte of the CDB before issuing a 
Select-and-Transfer command. 

Wait-for-Select-and-Receive: 

The 33C92A will store the second byte of the 
received CDB in this register. 



6.2.10 Sector Number Register/CDB 9th Byte 

Translate Address: 

This register will contain the resulting sector 
number following a Translate Address com- 
mand. 

Select-and-Transfer: 

This register should be loaded with the 
ninth byte of a ten or twelve byte CDB before 
issuing a Select-and-Transfer command. 

Wait-for-Select-and-Receive: 

The 33C92A will store the ninth byte of a ten 
or twelve byte received CDB in this register. 



6.2.8 Total Cylinders Register/CDB 3rd and 
4th Bytes 

Translate Address: 

This is a 16-bit register which holds the 
total number of cylinders. 



6.2.11 Head Number Register/CDB 10th Byte 

Translate Address: 

The HEAD NUMBER register contains the 
resulting head number following a Translate 
Address command. If automatic compensation 
for spare sectors on a disk is to be performed 
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by the WD33C92A, then the number of spare 
sectors per cylinder must be written into this 
register before issuing the Translate Address 
command. It should be noted that when 
compensation is used, the maximum number 
of cylinders allowed is 4096, and the maxi- 
mum number of heads is 15. An initial value of 
zero in this register indicates that no compen- 
sation is to be performed. 

Select-and-Transfer: 

This register should be loaded with the 
tenth byte of a ten or twelve byte CDB before 
issuing a Select- and-Transfer command. 

Wait-for-Select-and-Receive: 

The 33C92A will store the tenth byte of a ten 
or twelve byte received CDB in this register. 



6.2.12 Cylinder Number Register/CDB 11th 
and 12th Bytes 

Translate Address' 

The CYLINDER NUMBER register is a 16-bit 
register which contains the resulting cylinder 
number following execution of the Translate 
Address command. When a Translate Ad- 
dress command involving automatic compen- 
sation for spare sectors is issued (i.e. the 
HEAD NUMBER register initially contains a 
nonzero value), then this register must be 
loaded with total number of sectors per 
cylinder (total sectors/track * total heads - total 
spare sectors/cyl) before issuing the com- 
mand. 

Select-and-Transfer: 

This register should be loaded with the 
eleventh and twelfth bytes of a twelve byte 
CDB before issuing aSelect-and-Transfer com- 
mand. 

Wait-for-Select-and-Receive: 

The 33C92A will store the eleventh and twelfth 
bytes of a twelve byte received CDB in this 
register. 

Send-Status-and-Command-Complete: 

The CDB11 register is used to specify the 
returned status byte to be sent during a Send- 
Status-and-Command-Complete command. 
The CDB12 register is used to determine the 
type of Command-Complete message sent by 
the 33C92A. If bit of the CDB12 register is 



set to one, then a linked Command Complete 
message will be sent during command execu- 
tion. In this case, bit 1 of the CDB1 2 register is 
used as a FLAG bit to determine whether a 0A 
hex (FLAG=0) or a OB hex (FLAG=1 ) Linked 
Command Complete message is sent. If bit 
is zero, then a simple Command Complete 
message (00 hex) is sent. 



6.2.13 Target Lun Register 

The TARGET LUN register is used to hold both 
the Logical Unit Number (LUN) and Target status 
information during various 33C92A commands 
and sequences. During a Select-and-Transfer or 
Reselect-and-Transfer command, the contents of 
this register (along with the SOURCE ID register) 
are used to generate and check the IDENTIFY 
messages which are transferred across the SCSI 
bus. In addition, the TARGET LUN register is 
used to hold the Target Status byte received 
during a Select-and-Transfer command. 

During Wait-for-Select-and-Receive commands, 
this register may hold the image of the Identify 
message received from the Initiator. If the TLV bit 
is zero, there was no Identify message 
received. If the TLV bit is one, then a valid Identify 
message was received. The DOK bit will then in- 
dicate whether of not the Initiator has enabled dis- 
connects. 

During Reselect-and-Transfer commands, this 
register is used to set the LUN to be used in the 
Identify message sent to the Initiator after Selec- 
tion phase. The TLV and DOK bits are not 
used. 

In advanced mode, during Select-and-Transfer 
commands, this register is used to handle 
reselection by an unexpected Target. In this 
mode, this register will hold the logical unit num- 
ber of the reselecting target. The TLV and DOK 
bits will be set to zero. 
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Bit 0-2 TLx-Target LUN 

The Target Logical Unit Numbers bits 0-2. 
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Bit 3-5 Not Used 

Not used bits are zero. 
Bit 6 DOK-Disconnects OK 

Disconnects permitted. 
Bit 7 TLV-TARGET LUN Valid 

TARGET LUN Valid. 

6.2.14 Command Phase Register 

The COMMAND PHASE register is used during 
combination commands to indicate which phases 
of these multi-phase commands have been com- 
pleted. Thus, if the command has terminated 
abnormally, the processor can read this register to 
determine the cause of the termination and how to 
respond to it. This register is also used to resume 
combination commands by loading this 
register with a value that indicates the next 
desired or expected bus phase, and reissuing the 
command. Refer to the description of the specific 
commands for details regarding the various com- 
mand phases and resume values. 
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Bit 0-6 CPx-COMMAND PHASE bitsO-6 

Bit 7 Not Used. 

Not used bits are zero. 



6.2.15 Synchronous Transfer Register 

The SYNCHRONOUS TRANSFER register is 
used to select between synchronous and 
asynchronous transfers, and is also used to 
define the maximum transfer rate. For information 
phases other than a "data" transfer phase, or 
when the selected offset is zero 
(OF3=OF2=OF1=OF0=0), asynchronous trans- 
fers will occur. Values greater than zero define a 
synchronous transfer mode and the offset is 
determined as shown below. This offset deter- 
mines the effective FIFO depth for synchronous 
data transfers, and is typically determined by 
negotiation with the other SCSI device (as defined 
in the SCSI standard). The Transfer Period control 
bits select the minimum transfer period for both 
synchronous and asynchronous SCSI transfers 



and, if WD-Bus mode is used, the transfer period 
and the width of the RE-/WE- strobes for host 
transfers. The period is defined in terms of the 
internal clock cycle time; the frequency of this 
clock is determined by the divisor selected in the 
OWN ID register. 



7 


6 


5 


4 


3 


2 


1 








TP2 


TP1 


TPO 


OF3 


OF2 


OF1 


OFO 



Bit 0-3 OFx-OFFSET bit 0-3 

OFFSET bits 0-3 are used to select 
the desired offset according to the 
following: 
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Undefined 
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X 


Undefined 



Bit 4-6 TPx-TRANSFER PERIOD bits 0-3 

The TRANSFER PERIOD bits are used to 
select the desired transfer period 
according to the following table: 
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SCSI/Bus 
Transfer Period 


(SCSI REQ/ACK* 
& Bus RE-/WE- 
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8 cycles 


4 cycles 





1 





2 cycles 


1 cycles 





1 


1 


3 cycles 


1 cycles 


1 








4 cycles 


2 cycles 


1 





1 


5 cycles 


3 cycles 


1 


1 





6 cycles 


4 cycles 


1 


1 


1 


7 cycles 


4 cycles 



*synchronous pulse width & pulse width 
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The 'cycle' referred to above is the period of the 
internal data transfer clock after the divisor 
chosen in the OWN ID register is applied. This 
period is calculated by the following formula: 



cycle = divisor (from OWN ID)(nsec) / 2 * input clock frequency 
(MHz) 



6.2.17 Destination ID Register 

The DESTINATION ID register contains the en- 
coded SCSI bus ID of the device which is to be 
selected or reselected when a Reselect or Select 
command is issued. This register also contains 
control bits that affect the operation of certain 
combination commands. 



Bit 7 Not Used. 

Not used bits are zero. 

6.2.16 Transfer Count Register 

The TRANSFER COUNT register is a 24-bit 
register containing a preset value for the internal 
transfer counter. This preset value is loaded into 
the internal transfer counter when a Send, 
Receive, or Transfer command is issued. This 
counter is used to define command completion by 
decrementing as each data byte is transferred 
over the SCSI bus and causing a "successful 
completion" interrupt when the counter reaches 
zero. In Combination commands, this register 
specifies the number of bytes to be transferred 
during a Data phase. 

The counter function can be disabled by loading 
the TRANSFER COUNT register with zeros prior 
to issuing a command or by setting the SINGLE- 
BYTE TRANSFER bit in the COMMAND register 
concurrent with issuing the command. If the 
counter is disabled, the Send, Receive, or Trans- 
fer command will be completed when a single 
byte has been transferred. 

After the completion of any successful transfer, 
the TRANSFER COUNT register will be zero. 
This includes commands issued in Single Byte 
Transfer mode. 

When a transfer is interrupted by a halt on error 
condition, a SCSI bus phase change, or an abort, 
the TRANSFER COUNT register will contain the 
number of bytes NOT successfully transferred 
to/from the SCSI bus, including clearing the inter- 
nal FIFO of any bytes left in the FIFO (see DATA 
register). This FIFO clearing process may cause 
the TRANSFER COUNT register to differ with the 
user's DMA controller count, because some bytes 
may have been transferred into the FIFO, but not 
to the SCSI bus; therefore, the TRANSFER 
COUNT should be used to determine the actual 
number of bytes transferred to/from the SCSI bus. 
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Bit 0-2 Dlx-DESTINATION ID bits 0-2 

DESTINATION ID bits 0-2. 
Bit 3-5 Not Used. 

Not used bits are zero. 

Bit 6 DPD-DATA PHASE DIRECTION, 

DATA PHASE DIRECTION, when ad- 
vanced features are enabled (see 7.3), is 
used to specify the expected direction of 
the SCSI data phase, when it occurs. This 
allows the 33C92A to verify the direction 
during Select-and-Transfer commands 
before beginning the transfer. When this 
bit is zero, the expected direction is out (to 
the Target). When this bit is one, the ex- 
pected direction is in (from the Target). An 
unexpected information phase error will 
occur if the direction does not match the 
setting of this bit. 

Bit 7 SCC-SELECT COMMAND CHAIN 

SELECT COMMAND CHAIN is used only 
when the Reselect-and-Transfer com- 
mand is issued with EDI=1. This bit 
selects which command is chained to 
when the data transfer is completed. 
When this bit is zero, a Send-Status-and- 
Command-Complete command begins ex- 
ecuting. When this bit is one, a Send-Dis- 
connect-Message command begins ex- 
ecuting. 



6.2.18 Source ID Register 

The SOURCE ID register is used to report the 
SCSI bus ID of the device that has selected or 
reselected the 33C92A. It also contains bits that 
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enable and control response to selection and 
reselection. 
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Bit 7 ER-ENABLE RESELECTION 

ENABLE RESELECTION, when set to 
one, enables the 33C92A to respond to a 
reselection by another device on the SCSI 
bus. When this bit is zero, any reselection 
is ignored. 

Bit 6 ES-ENABLE SELECTION 

ENABLE SELECTION, when set to one, 
enables the 33C92A to respond to a 
selection by another device on the SCSI 
bus. When this bit is zero, any selection is 
ignored. 

Bit 5 DSP-DISABLE SELECT PARITY 

DISABLE SELECT PARITY, when set to 
one, causes the 33C92A to ignore the bus 
parity when responding to selection or 
reselection. When this bit is zero, any 
selection or reselection with a parity error 
is ignored. 

Bit 4 Not Used. 

Not used bits are zero. 

Bit 3 SIV-SOURCE ID VALID 

SOURCE ID VALID is set to one after the 
33C92A is selected or reselected if the 
other SCSI bus device asserted its own 
bus ID bit (in addition to the bus ID bit of 
the 33C92A) during the select/reselect 
phase. This bit is zero if only the bus ID bit 
of the 33C92A was asserted. 

Bit 2-0 SIx-SOURCE ID Bits 2-0 

SOURCE ID Bits 2-0 are valid only if the 
SIV bit is set to one. These bits indicate 
the SCSI bus ID of the device that 
selected or reselected the 33C92A. 



6.2.19 SCSI Status Register 

The SCSI STATUS register is a read-only register 
which indicates the cause of the most recent 
INTRQ assertion. INTRQ is asserted whenever a 
condition occurs within the 33C92A that requires 
intervention by the host; for example: 



the 33C92A has been reset; 

the command completed successfully; 

the bus phase changed; 

an error occurred. 



Once INTRQ has been asserted, the contents of 
this register will not change until after the SCSI 
STATUS register has been read or until the 
33C92A has been reset. 
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Bit 0-3 SSx-SCSI STATUS bits 0-3 

SCSI STATUS bits 0-3 are status 
qualifiers whose meaning depends upon 
which upper (4-7) status bit is set. 

Bit 4-7 SSx-SCSI STATUS bits 4-7 

SCSI STATUS bits 4-7 define the type of 
interrupt that occurred. The possible 
codes are defined in the following table: 



STATUS CODE 


GROUP MEANING 


0000 xxxx 


The 33C92A is in a reset state. 


0001 xxxx 


A 33C92A command has completed 
successfully. 


0010 xxxx 


A 33C92A command has paused or 
was aborted by an Abort command. 


01 00 xxxx 


A 33C92A command has been ter- 
minated prematurely due to an error 
or other unexpected condition. 


1000 xxxx 


An event on the SCSI bus requires 
service. 



All other Status Code groups are currently not 
used and are reserved for future use. 

In the following tables, the 'STATE' column indi- 
cates the current state in which the Status Code 
can occur. Also, the MCI field refers to the signals 
that define a SCSI bus information transfer phase: 
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MSG, C/D, and I/O. A bit set to one indicates 
that the signal is asserted on the SCSI bus. A 
zero indicates negation. Whenever one of these 
Status Codes occurs, the REQ signal is asserted 
on the SCSI bus. The following table summarizes 
the meaning of the MCI field: 



MCI CODE 


MEANING 


000 


Data Out phase 


001 


Data In phase 


010 


Command phase 


011 


Status phase 


100 


Unspecified Info Out phase 


101 


Unspecified Info In phase 


110 


Message Out phase 


111 


Message In phase 



STATUS CODE 


STATE 


SPECIFIC MEANING 


0000 0000 


DTI 


33C92 Reset. The device has been reset, or a Reset command 
has executed successfully with no advanced features enabled. 
The new state of the 33C92A is disconnected. 


0000 0001 


DTI 


33C92A Reset. The device has successfully completed a Reset 
command with advance features enabled. The new state of the 
33C92A is disconnected. 



TABLE 6-2. RESET STATE INTERRUPTS 
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STATUS CODE 


STATE 


SPECIFIC MEANING 


0001 0000 


D 


A Reselect command completed successfully. The new state of the 
33C92A is connected as a Target. 


0001 0001 


D 


A Select command completed successfully. The new state of the 
33C92A is connected as an Initiator. 


0001 0010 


- 


Reserved for future use. 


0001 0011 


DT 


A Receive, Send, Reselect-and-Transfer, Wait-for-Select-and- 
Receive, Send-Status-and-Command-Complete, or a Send-Discon- 
nect-Message command completed successfully (ATN 
is not asserted). 


0001 0100 


DT 


A Receive, Send, Reselect-and-Transfer, Wait-for-Select-and- 
Receive, Send-Status-and-Command-Complete, or a Send-Discon- 
nect-Message command completed successfully (ATN 
is asserted). 


0001 0101 


DT 


A Translate Address command completed successfully. 


0001 0110 


Dl 


A Select-and-Transfer command completed successfully. 


0001 0111 


- 


Reserved for future use. 


0001 1MCI 


I 


A Transfer (non-MESSAGE IN phase) command completed suc- 
cessfully. MCI defines the new information type (SCSI bus phase) 
being requested. 




TABLE 6-3. SUCCESSFUL COMPLETION INTERRUPTS 
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STATUS CODE 


STATE 


SPECIFIC MEANING 


0010 0000 


I 


A Transfer Info (MESSAGE-IN phase) command has paused with 
ACK asserted. This allows the host to examine the message before 
accepting it. 


0010 0001 


I 


A Save- Data- Pointer message was received during a Select-and- 
Transfer command. The host should save its current data buffer 
pointer. 


0010 0010 


D 


A Select or Reselect command was aborted. 


0010 0011 


T 


A Receive or Send command was halted by an error or was 
aborted (ATN is not asserted). 


0010 0100 


T 


A Receive or Send command was halted by an error, assertion of 
ATN, or was aborted (ATN is asserted). 


0010 0101 


D 


Reserved for future use. 


0010 0110 


- 


Reserved for future use. 


0010 0111 


D 


The 33C92A has been reselected during a Select-and-Transfer 
(with IDI=0) by a Target that does not match the SCSI bus ID 
loaded into the DESTINATION ID register, or the following Identify 
message did not match the LUN loaded into the TARGET LUN 
register. ACK has been left asserted following the Identify mes- 
sage, and the bus ID and LUN of the reselecting Target are avail- 
able in the SOURCE ID and TARGET LUN registers. (Advanced 
Mode only) 


0010 1MCI 


I 


A Transfer command was aborted. MCI define the new information 
type (SCSI bus phase) being requested. 



TABLE 6-4. PAUSED OR ABORTED INTERRUPTS 
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STATUS CODE 


STATE 


SPECIFIC MEANING 


0100 0000 


DTI 


An invalid command was issued. 


0100 0001 


I 


An unexpected disconnect (SCSI bus free) by the Target caused a 
command to terminate. The new state of the 33C92A is discon- 
nected. 


0100 0010 


D 


A timeout occurred during a Select or Reselect command. The 
state of the 33C92A is disconnected. 


0100 0011 


Tl 


A parity error caused a command to terminate ATN is not as- 
serted). The transfer direction determines whether it is a SCSI or 
host parity error. 


0100 0100 


Tl 


A parity error caused a command to terminate (ATN is asserted). 
The transfer direction determines whether it is a SCSI or host 
parity error. 


0100 0101 


DT 


The Logical Address exceeded the disk boundaries. 


0100 0110 


D 


A Target whose SCSI bus device ID does not match the bus ID set 
in the DESTINATION ID register has reselected the 33C92A 
during a Select-and-Transfer command (with IDI=0). This interrupt 
occurs when the 33C92A is not in Advanced Mode. The new state 
of the 33C92A is connected as an Initiator. 


0100 0111 


I 


A status byte with bad parity was received during a Select-and- 
Transfer command. ACK is asserted. 


0100 1 MCI 


I 


An unexpected information phase was requested. MCI define the 
SCSI bus phase which is requested.This is typically caused 
by a phase change before the Transfer Counthas reached zero, or 
an unexpected phase sequence occurred during a Select-and- 
Transfer command. 




TABLE 6-5. TERMINATED INTERRUPTS 
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STATUS CODE 


STATE 


SPECIFIC MEANING 


1000 0000 


D 


The 33C92A has been reselected. The new state of the 33C92A is 
connected as an Initiator. No Identify message transfer has yet oc- 
curred. 


1000 0001 


D 


The 33C92A has been reselected in Advanced Mode. The SCSI 
bus ID of the Target may be read from the SOURCE ID register. 
The Identify message from the Target may be read from the DATA 
register. The ACK signal is left asserted. The new state of the 
33C92A is connected as an Initiator. 


1000 0010 


D 


The 33C92A has been selected (no ATN assertion). The new state 
of the 33C92A is connected as a Target. 


1000 0011 


D 


The 33C92A has been selected (ATN was asserted). The new 
state of the 33C92A is connected as a Target. 


1000 0100 


T 


The ATN signal has been asserted. 


1000 0101 


I 


A disconnect has occurred. The new state of the 33C92A is discon- 
nected. 


1000 0110 


- 


Reserved for future use. 


1000 0111 


T 


The Wait-for-Select-and-Receive command has paused because 
the first byte of the incoming CDB is not a known command group. 
The OWN ID register must be loaded with the CDB length,and the 
command resumed. The CDB1 register may be examined to deter- 
mine the SCSI command group from the opcode. The new state of 
the 33C92A is connected as a Target. (Advanced Mode only) 


1000 1 MCI 


I 


The REQ signal has been asserted following connection or when 
the 33C92A is in the Initiator state and no command is executing. 
The information phase type should be examined. MCI define the 
information phase (SCSI bus phase) which is being requested. 



TABLE 6-6. SERVICE REQUIRED INTERRUPTS 
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6.2.20 Command Register 

The COMMAND register is used to issue the 
33C92A commands. This register should never be 
loaded when the CIP or INT bits (in AUXILIARY 
STATUS) are set to one, and a Level II command 
should never be loaded when the BSY bit is set to 
one. 

The SINGLE-BYTE TRANSFER (SBT) bit in the 
COMMAND register is only used during informa- 
tion transfer type commands. When this bit is set 
in conjunction with one of these commands, the 
transfer counter is disabled and exactly one byte 
is to be transferred, regardless of the value in the 
TRANSFER COUNT register. The previous con- 
tents of the TRANSFER COUNT register are not 
preserved. 

Refer to the COMMANDS section for a descrip- 
tion of the commands and their corresponding 
command codes. 



7 


6 


5 


4 


3 


2 


1 





SBT 


CC6 


CC5 


CC4 


CC3 


CC2 


CC1 


CCO 



Bit 0-6 CCx-COMMAND CODE bits 0-6 

COMMAND CODE bits 0-6. 
Bit 7 SBT-SINGLE-BYTE TRANSFER 

SINGLE-BYTE TRANSFER bit. 



done so that the FIFO is returned to a ready state 
for subsequent transfers, and to flush incoming 
data to the host bus. 

The DATA register is accessed by the processor 
during a data phase when the CONTROL register 
DMA mode select bits are all reset (=0), and when 
the DBR bit in the AUXILIARY STATUS register 
is true. The processor writes (reads) the DATA 
register by loading the ADDRESS register with a 
hex value of 19 and asserting the WE- (RE-) and 
CS- pins. This access also occurs during non- 
data phases. 

When the CONTROL register DMA mode select 
bits are set for DMA mode or BURST mode, the 
DMA interface is enabled. In this case, the DATA 
register is written (read) when the DACK- and 
WE-(RE-) pins are asserted in response to the 
assertion by the 33C92A of the DRQ- pin. 

When the WD BUS is selected by the DMA mode 
select bits, the RCS- pin functions as an external 
buffer chip select and the WE- and RE- pins be- 
come outputs, allowing the 33C92A to automat- 
ically transfer data between its DATA register and 
the external buffer. In this mode, bus control can 
be returned to the external processor or any other 
device by negating the DRQ pin. 




6.2.21 Data Register 

The DATA register is used to transfer data bytes 
between the host and the SCSI bus during the 
SCSI information transfer phases (command, 
data, status, or message phase). It may be ac- 
cessed by the processor during any type of infor- 
mation phase (simple Level II commands) or via 
the DMA/WD interface during a SCSI Data In 
phase or Data Out phase (simple and combina- 
tion Level II commands). 

The DATA register is actually a port for the host 
interface into the internal twelve byte FIFO of the 
33C92A. The FIFO is used for all transfers 
(synchronous and asynchronous) between the 
SCSI bus and the host bus, for both DMA and 
processor access transfers. If the 33C92A is to be 
halted for any reason (through ABORT, for ex- 
ample), then data transfers with this FIFO must 
continue until an interrupt occurs. This must be 
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6.3 RESET CONDITIONS 



6.3.1 Hardware Reset 

The following results occur when the 33C92A Is 
reset by the assertion of the MR- signal: 



• The AUXILIARY STATUS register is reset to 
zero. The INT bit (and the INTRQ pin) is set to 
one when the hardware reset completes. 

• The OWN ID register is reset to zero. 

• Advanced mode is disabled. 

• The ES, ER, and DSP bits in the SOURCE ID 
register are reset to zero. 

• The SCSI STATUS register is reset to zero. 

• The internal FIFO, internal transfer counter (not 
the host accessible register), offsets, and state 
machines are cleared. 

• The internal clock divider circuit is set to divide 
by two. 

• The following host accessible registers are 
NOT affected by the MR- signal: 

- Registers 01 hex through 15 hex; 

- SOURCE ID (16 hex) register bits 0-3; 

- COMMAND register (18 hex); 

The SCSI Soft Reset may be implemented by 
using the SCSI bus reset signal to cause a reset 



of the 33C92A (for example, OR the host power 
on reset signal with the received SCSI bus reset 
(RST) signal). The host may examine the 
registers that are not affected by the MR- signal to 
recover from the SCSI reset condition. 



6.3.2 Software Reset 

The following results occur when the 33C92A ex- 
ecutes the Reset command: 

• The DBR bit in the AUXILIARY STATUS 
register is reset to zero. The INT bit (and 
INTRQ pin) is set to one when the Reset 
command is complete. 

• All SCSI bus signals are reset to the negated 
state. 

• The internal FIFO, internal transfer counter (not 
the host accessible register), offsets, and state 
machines are cleared. 

• The OWN ID register is interpreted and the 
clock divisor, host parity, and advanced mode 
are configured. 

• Registers 01 hex through 16 hex are reset to 
zero. The COMMAND register (18 hex) is also 
reset to zero. 

• The SCSI STATUS register is set as 
commanded by the EAF bit in the OWN ID 
register. 
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7.0 COMMANDS 

7.1 COMMAND LIST 



COMMAND 
CODE (HEX) 


COMMAND 


VALID 
STATES 


LEVEL 


00 


Reset 


D,T,I 




01 


Abort 


D,T 




02 


Assert ATN 


I 




03 


Negate ACK 


I 




04 


Disconnect 


T,l 




05 


Reselect 


D 




06 


Select-with-ATN 


D 




07 


Select-without-ATN 


D 




08 


Select-with-ATN-and-Transfer 


D,l 




09 


Select-without-ATN-and-Transfer 


D,l 




0A 


Reselect-and-Receive-Data 


D,T 




0B 


Reselect-and-Send-Data 


D,T 




OC 


Wait-for-Select-and-Receive 


D,T 




OD 


Send-Status-and-Command-Complete 


T 




OE 


Send-Disconnect-Message 


T 




OF 


Set IDI 


D,T,I 




10 


Receive Command 


T 




11 


Receive Data 


T 




12 


Receive Message Out 


T 




13 


Receive Unspecified Info Out 


T 




14 


Send Status 


T 




15 


Send Data 


T 




16 


Send Message In 


T 




17 


Send Unspecified Info In 


T 




18 


Translate Address 


D,T 




20 


Transfer Info 


I 






33C92A States: 

D = Disconnected 

T = Connected as a Target 

I = Connected as an Initiator 

Command Levels: 

I = Level I command 

II = Level II command 
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7.2 33C92A COMMAND TYPES 

There are two basic types of 33C92A commands: 
Level I and Level II. Level I commands may be 
issued while a Level II command is in progress 
(indicated by an AUXILIARY STATUS of 
BSY=1,CIP=0) and, except for the "Abort" and 
"Reset" commands, do not generate an interrupt 
upon their completion. Level II command execu- 
tion will always result in an interrupt. If a Level II 
command is issued while another Level II com- 
mand is executing, unpredictable results may 
occur. 

There are two types of Level II commands. 
'Simple' Level II commands are associated with a 
single operation or phase (for example, selection 
or information transfer). 'Combination' Level II 
commands combine multiple phases into a single 
33C92A command to minimize interrupt overhead. 
The Initiator combination commands 'expect' cer- 
tain SCSI bus phases at certain times during 
a sequence. These expected phases are based 
on common sequences performed by a Target on 
the SCSI bus; any deviation causes an interrupt. 
Target combination commands can be chained 
together to further minimize interrupt overhead by 
creating longer phase sequences. 

NOTE: When using command chaining, care 
must be taken to ensure that all commands in the 
chain are initialized prior to issuing the command. 

The 33C92A will be in one of three "states" during 
operation: Disconnected, Connected as a Target, 
or Connected as an Initiator. Certain commands 
are valid only in particular states as indicated in 
the COMMAND LIST. An attempt to issue a 
Level II command which is invalid for the present 
33C92A state will cause an "invalid command" in- 
terrupt. Level I commands issued in invalid states 
will be ignored. 



7.3 ADVANCED MODE FEATURES 

The 33C92A has several new features included 
which add new functions to the original 33C92 
design. Some of these features cause the 
33C92A to be incompatible with the 33C92. 
These features have been grouped together 
under the heading of 'Advanced Mode' features. 
These features are disabled when the 
33C92A is reset by the MR- signal (hardware 
reset). They must be enabled by the host by issu- 
ing the 'Reset' command with the 'Enable Ad- 



vanced Features' (EAF) bit set in the OWN ID 
register. The host can determine if advanced fea- 
tures have been enabled (thereby implying that a 
33C92A is installed) by examining the SCSI 
STATUS register after issuing the 'Reset' com- 
mand. 

The features enabled by this bit are described in 
the subsections below. 



7.3.1 Unexpected Reselection 

When in normal (33C92) mode, a reselection 
when idle (ER=1) or when disconnected during a 
Select-and-Transfer command (and the Target 
bus ID does not match the DESTINATION ID 
register) causes an immediate interrupt after 
the reselection handshake is complete. In Ad- 
vanced Mode, the 33C92A will continue to the 
Message In phase to fetch the Identify message. 
If the 33C92A was idle, the SCSI STATUS register 
will be set to 81 hex, and the Identify message will 
be in the DATA register. If the 33C92A was ex- 
ecuting a Select-and-Transfer command, the 
SCSI STATUS register will be set to 27 hex, and 
the Identify message will be in the TARGET LUN 
register. In either case, the SOURCE ID register 
will contain the SCSI bus ID of the respecting 
Target, and the ACK signal remains asserted so 
that the Identify message may be rEjected. 



7.3.2 Unknown SCSI Command Groups 

When a SCSI Command Descriptor Block is 
transferred on the SCSI bus, the command length 
in bytes is determined by the group code, which is 
found in bits 7-5 of the first command byte, or 
opcode. Group (opcodes 00 to 1 F hex), group 1 
(opcodes 20 to 3F hex), and group 5 (opcodes A0 
to BF hex) commands are defined by the SCSI 
standard (X3.131-1986) as six, ten, and twelve 
byte commands, respectively. All other command 
groups are undefined by that standard. In normal 
mode, the 33C92A will assume that these un- 
defined groups are six byte commands when ex- 
ecuting Select-and-Transfer or Wait-for-Select- 
and-Receive commands. In Advanced Mode, the 
following events will occur: 

Select-and-Transfer: 

When loading the CDB into the CDB 
registers prior to issuing the command, the 
host also loads the expected command length 
into the OWN ID register. The 33C92A uses 
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this value to make sure the correct number of 
bytes are then transferred in the command 
phase. 

Wait-for-Select-and-Receive 

When receiving the CDB from the Initiator, the 
33C92A will check the first CDB byte as soon 
as it is received. If the group is undefined, an 
interrupt will occur so that the host can ex- 
amine the first command byte in the CDB 1ST 
register, and then load the TOTAL command 
length into the OWN ID register. The SCSI 
STATUS register is set to 87 hex, and the 
COMMAND PHASE register is set to 31 hex, 
when this interrupt occurs. After the interrupt, 
the 33C92A will only accept a Resume Wait- 
for-Select-and-Receive command, Abort, Dis- 
connect, or Reset command. All other com- 
mands are invalid; during the interrupt process- 
ing, the 33C92A will continue to transfer the 
first six bytes of the command into its internal 
FIFO. 



7.3.3 Data Phase Direction 

During a Select-and-Transfer command in normal 
mode, the Data phase direction is determined 
solely by the Target; if this direction does not 
match the direction expected by the host, the 
33C92A will not detect this error but expects that 
the transfer will continue. In Advanced Mode, the 
DPD bit in the DESTINATION ID register is com- 
pared with the state of the I/O signal on the SCSI 
bus. If the expected and actual directions do not 
match, an interrupt will occur with 'unexpected 
phase' status in the SCSI STATUS register. 



7.4 LEVEL I COMMANDS 



7.4.1 Reset (00 hex) 

The Reset command performs a similar function 
to the hardware reset caused by asserting the 
MR- pin except that the OWN ID register is 
sampled for information concerning the 
operating configuration of the 33C92A. The 
33C92A is also initialized as described in the 
RESET CONDITIONS section. The Reset com- 
mand may be executed in any 33C92A state and 
will force the 33C92A into the Disconnected state, 
aborting any previously issued command in 
progress. Upon completion of the Reset com- 



mand, an interrupt is generated the SCSI 
STATUS will be 00 hex or 01 hex, depending on 
the contents of the OWN ID register. 



7.4.2 Abort (01 Hex) 

The Abort command is valid in the Disconnected 
and Connected-as-Target states. The Abort com- 
mand has different effects depending on the state 
and the command that is currently executing, 
as described below: 

Disconnected State 

In the Disconnected state, the Abort command 
may be used to halt an attempted Select, 
Select-and-Transfer, Reselect, or Reselect- 
and-Transfer command. If the Abort command 
is issued following a Select or Reselect com- 
mand and the WD33C92A has won arbitra- 
tion, the WD33C92A releases the SCSI bus 
by removing the Bus ID bits while SEL- is as- 
serted and checking for a negated BSY- sig- 
nal. If, after at least 200 us, there is no BSY- 
response, the WD33C92A goes to a Bus Free 
condition, and a "paused/aborted" interrupt is 
generated. If there is a response within this 
time period, then a "successful completion" in- 
terrupt will result instead. If the WD33C92A 
has not yet won arbitration, it will immediately 
abort the Select or Reselect command. The 
abort command will also terminate a Wait- 
for-Select-and-Receive command, if selection 
has not already begun. Once selected, the 
WD33C92A will ignore any abort attempts, 
and the command will finish normally. 

Target State 

When the WD33C92A is in a Connected-as-a- 
Target state, the Abort command may be used 
to abort Receive, Send, or the data phase por- 
tion of a Target combination command. 
When issuing an Abort in the Connected-as-a- 
Target state, the following rules apply: 

1 . When a Abort command is issued to abort 
a Send or Reselect-and-Send command, 
the local processor must not service any 
data request (DBR, DRQ, etc.) from the 
WD33C92A until an interrupt from the 
WD33C92A occurs. This is required to 
allow the FIFO to clear; the Abort process- 
ing will not complete until the FIFO 
contents are flushed to the SCSI bus. The 
WD33C92A removes the data request at 
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an arbitrary time during the Abort com- 
mand processing and the data request is 
not valid once the Abort command is writ- 
ten to the COMMAND register. 

2. When a Abort command is issued to abort 
a Receive or Reselect-and-Receive com- 
mand, the local processor must CON- 
TINUE to service any data request (DBR, 
DRQ, etc.) from the WD33C92A until an 
interrupt from the WD33C92A occurs. 
This is required to allow the FIFO to clear; 
the Abort processing will not complete 
until the FIFO contents are flushed to the 
local processor. 

After the Abort command is processed and the 
local processorhas received the interrupt indicat- 
ing this, the TRANSFER COUNT register contains 
the number of bytes that were not successfully 
transferred with the SCSI bus. The WD33C92A 
remains in the Connected-as-a-Target state. The 
WD33C92A is now ready to receive any ap- 
propriate Target mode command, including a 
resume of the command that was aborted. 



7.4.3 Disconnect (04 hex) 

The Disconnect command may be used in either 
the Target or the Initiator connected states. In the 
Target role, the Disconnect command is the nor- 
mal procedure for disconnecting from the SCSI 
bus following the information transfer phase. In 
the Initiator role, Disconnect can be used to 
release the bus following a timeout condition. The 
Disconnect command causes the immediate 
release of all bus signals and, in Target mode, 
returns the SCSI bus to the Bus Free phase. If the 
Disconnect command is issued during an active 
Level II command, the Level II command is 
immediately terminated and the 33C92A transi- 
tions to the Disconnected state. 



7.4.4 Assert ATN (02 hex) 

The Assert ATN command is only valid when Con- 
nected as an Initiator. It is normally used to allow 
the Initiator to inform a Target that it has a mes- 
sage pending (The Target is expected to 
respond by performing a Message Out Phase). 
ATN is automatically negated: 



• before the last byte of a Transfer Info 
command issued in response to the Message 
Out phase; 

• when the Identify message out is transferred to 
the Target during a Select-and-Transfer 
command; 

• when a SCSI Bus Free phase occurs. 

The Select-with-ATN and Select-with-ATN-and- 
Transfer commands will cause the 33C92A to 
automatically assert ATN prior to the release of 
SEL- providing the bus arbitration is won. 



7.4.5 Negate ACK (03 hex) 

The Negate ACK command causes ACK to be 
negated. It may be used: 

• When Connected as an Initiator following 
Message-In Transfer Info commands. 

• After the 33C92A has detected a parity error on 
any received information and the HALT on 
SCSI PARITY ERROR (HSP) bit is set. 

• After unexpected reselection in advanced 
mode. 

• After a Save-Data-Pointer message is received 
during a Select-and-Transfer command. 

• Host parity errors do not affect the ACK signal. 
For all other Initiator transfers, ACK negation is 
automatic. 



In the case of a Message-In transfer, incoming 
messages may be rejected and the Initiator may 
indicate its intent to send either a "MESSAGE 
REJECT" or a "MESSAGE PARITY ERROR" 
Message by issuing the Assert ATN command 
prior to issuing the Negate ACK command. If the 
incoming message is to be accepted, only the 
Negate ACK command should be issued. 

During non-Message- In transfers, if the Transfer 
command is terminated by a parity error, the As- 
sert ATN command can again be issued prior to 
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Negate ACK, this time indicating the Initiator's 
intent to send an "INITIATOR DETECTED 
ERROR" Message. 



7.4.6 Set IDI (OF hex) 

The Set IDI command is used in the Initiator role 
to support overlapped SCSI operations. If a SCSI 
command is executing via a Select-and-Transfer 
command, then the Set IDI command may be 
used to set the IDI bit in the CONTROL register, 
which then causes an interrupt to occur upon a 
Target disconnection. This ability allows the IDI bit 
to be left reset when the first SCSI operation 
is started, which may reduce the number of 
33C92A interrupts, yet also allows a second 
operation to be started when needed without 
waiting for the first operation to be completed. 



7.5 SIMPLE LEVEL II COMMANDS 



7.5.1 Select-with-ATN (06 hex) 

Select-with-ATN is valid only in the Disconnected 
state and when issued will cause the 33C92A to 
select a Target. Before issuing this command, the 
SCSI Bus ID of the Target device should be writ- 
ten into the DESTINATION ID register. When the 
Select-with-ATN command is issued, the 33C92A 
begins bus arbitration. If the 33C92A is selected 
or reselected by another device during the arbitra- 
tion, the Select-with-ATN command is aborted 
and a "service required" interrupt (8x hex) is 
generated. 

Should the 33C92A win the arbitration, SEL- and 
ATN are asserted, the Target and Initiator Bus IDs 
are placed on the SCSI data bus, and then BSY- 
is deasserted. At this time, a timeout sequence 
whose length is determined by the value in the 
TIMEOUT PERIOD register begins. If BSY- is not 
asserted by the Target before a timeout occurs, 
the 33C92A begins its selection abort sequence 
(as described in the Abort command description), 
and if there is no Target response\the Select-with- 
ATN command is terminated and a "terminated" 
interrupt is generated. If the Target responds 
before the timeout period has elapsed or before 
the selection abort sequence is complete, the 
33C92A negates the SEL-signal, putting the 
33C92A in a Connected-as-an-lnitiator state. A 
"successful completion" interrupt indicates that 



the Select-with-ATN command has been com- 
pleted successfully. 

If the 33C92A does not win the arbitration or there 
is no response from the Target and the timeout 
feature is disabled, the Select-with-ATN command 
can be aborted with an Abort command. 
When the Abort command is successfully ex- 
ecuted under these circumstances, the 33C92A is 
disconnected from the bus and a "paused/ 
aborted" interrupt is generated. 



7.5.2 Select-without-ATN (07 hex) 

The Select-without-ATN command is identical to 
the Select-with-ATN command except that ATN is 
not set during the Selection Phase. 



7.5.3 Reselect (05 hex) 

The Reselect command is identical to the Select- 
without-ATN command except that the I/O signal 
is asserted upon completion of the Arbitration 
Phase. Successful completion of the Reselect 
command results in the 33C92A being Connected 
as a Target. 



7.5.4 Receive (1 0-1 3 hex) 

There are four Receive commands which are dis- 
tinguished from each other only by the state of 
three SCSI interface signals and the type of data 
that is transferred. These commands, consisting 
of the Receive Command, Receive Data, Receive 
Message Out, and Receive Unspecified Info Out 
commands are valid only in the Connected-as-a- 
Target state. The type of the Receive command 
selected determines the state of the I/O-, C/D-, 
and MSG outputs during the command according 
to the following chart (1 =asserted): 




Receive 
Command Type 


OP 
Code 


MSG 


C/D 


I/O 


Receive Command 


10 





1 





Receive Data 


11 











Receive Message Out 


12 


1 


1 





Receive Unspecified 
Info Out 


13 


1 









The Receive commands are information transfer- 
ring commands and are therefore dependent on 
the SBT bit in the COMMAND register for deter- 
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mination of a successful completion. In addition to 
a termination caused by reset (via either a Reset 
command being issued or assertion of the MR- 
pin), a Receive command completion or termina- 
tion will occur under any of these conditions: 

1. The internal transfer counter is disabled 
(SBT=1 or the TRANSFER COUNT 
register is loaded with zero) and a single 
byte has been read from the DATA 
register. 

2. The counter has decremented to zero (with 
SBT=0) indicating that the specified num- 
ber of bytes have been transferred. 

3. A parity error has been detected on one of 
the received data bytes (and HSP=1). 

4. The ATN pin is asserted (and HA=1). 

5. The Abort command is issued. 

6. A Disconnect command is issued. 

When the Receive command is completed as a 
result of receiving the correct number of bytes, a 
"successful completion" interrupt will be 
generated. If a parity error has caused termina- 
tion, a "terminated" interrupt will instead be 
generated. In this case, the TRANSFER COUNT 
register will contain the number of bytes yet to be 
transferred. After any completion or termination of 
the Receive commands except those due to a 
subsequent Disconnect command or reset, the 
33C92A is in the Connected-as-a-Target state. 

As data transfer commands, the Receive com- 
mands are dependent on the DMA mode select 
bits in the CONTROL register for the DATA 
register accessing mode. These bits determine 
whether the DATA register accesses will be hand- 
led by the processor or through a DMA/WD inter- 
face. When the processor is required to read the 
DATA register (i.e. DMA mode select bits=0), it 
must monitor the DBR status bit (in AUXILIARY 
STATUS) to determine when a byte is available 
for reading. During Receive commands, this 
status bit will be reset when a byte is read from 
the DATA register and set when a byte is loaded 
into the DATA register via the SCSI interface. 
DBR is also reset when a Receive command is 
issued. 

All information transfers involving other than data 
information are asynchronous. However, if the in- 
formation phase involves data transfers, the 



SYNCHRONOUS TRANSFER register will be 
evaluated. In this case, any selected offset other 
than zero results in synchronous transfers. The 
minimum Transfer Period for both types of trans- 
fers is determined by the transfer period bits 
in this same register. 



7.5.5 Send (14-17 hex) 

As in the case of the Receive commands, there 
are four Send commands which are distinguished 
only by the state of the l/0-,C/D-, and MSG pins 
and the type of data that is transferred. The 
four Send commands, also valid in the Con- 
nected-as-a-Target state only, are the Send 
Status, Send Data, Send Message In, and Send 
Unspecified Info In commands. The SCSI pin 
states during the Send commands are determined 
by the particular command as follows (as- 
serted^): 



Send 
Command Type 


OP 
Code 


MSG 


C/D 


I/O 


Send Status 


14 





1 


1 


Send Data 


15 








1 


Send Message In 


16 


1 


1 


1 


Send Unspecified Info 
In 


17 


1 





1 



The Send commands are also information trans- 
ferring commands and as such are also depend- 
ent upon the SBT bit in the COMMAND 
register for command completion. In addition to 
that caused by reset (via either a Reset command 
being issued or assertion of the MR- pin), a Send 
command completion or termination will occur 
under any of these conditions: 

1. The internal transfer counter is disabled 
(SBT=1 or the TRANSFER COUNT 
register is loaded with zero) and a single 
byte has been read from the DATA 
register. 

2. The counter has decremented to zero (with 
SBT=0) indicating that the specified num- 
ber of bytes have been transferred 

3. A parity error has been detected on one of 
the data bytes from the host (and HHP=1 ). 

4. The ATN pin is asserted (and HA=1). 

5. The Abort command is issued. 
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6. A Disconnect command is issued. The 
33C92A remains Connected-as-a-Target 
following the Send command comple- 
tion/termination unless the Disconnect 
command or reset was used to force a 
termination. 

During a Send command, DATA register access- 
ing is controlled by the DMA mode select bits in 
the CONTROL register. When these bits are set 
to the appropriate mode, loading of the DATA 
register is accomplished by a DMA controller or 
through the WD-Bus interface. If the DMA mode 
select bits are zero, the processor must poll the 
AUXILIARY STATUS register and can write to the 
DATA register only when the DATA BUFFER 
READY bit is set (DBR=1). Send commands 
cause the DBR bit to be reset every time the 
processor loads a byte into the DATA register and 
set when a byte is transferred from the DATA 
register onto the SCSI data bus. The DBR bit will 
also be set upon issuing a Send command. 

As in the case of Receive commands, 
synchronous transfers will occur only when data 
transfers are involved and an offset other than 
zero is selected. 



7.5.6 Transfer Info (20 hex) 

The Transfer Info command is valid only when 
Connected as an Initiator and is used to send and 
receive data, command, status, and message in- 
formation. 

The first REQ assertion following connection as 
an Initiator results in a "service required" interrupt. 
The processor should examine the SCSI STATUS 
register to determine the type and direction of in- 
formation transfer requested by the Target, and 
then issue a Transfer Info command in response. 
While an Initiator, the 33C92A will also generate 
an interrupt each time the Target device requests 
a new type of information transfer phase. 

As in the case of the Send and Receive com- 
mands, when completion of the Transfer Info com- 
mand depends upon the internal transfer counter, 
the processor should load the TRANSFER 
COUNT register prior to issuing this command. 
The DMA mode select bits in the CONTROL 
register, the offset and transfer period bits in the 
SYNCHRONOUS TRANSFER register, and the 
SBT bit in the COMMAND register are used 
during Transfer Info commands just as they are 



during the Send and Receive commands. How- 
ever, for processor access of the DATA register 
during Transfer Info commands (when the DMA 
mode select bits are zero or the bus phase is 
other than Data phase), behavior of the DATA 
BUFFER READY (DBR) status bit is determined 
by the direction of information transfer as defined 
by the I/O- pin. When the transfer is from Initiator 
to Target, the DBR bit is reset by writing to the 
DATA register and is set when the byte is trans- 
ferred from the DATA register onto the SCSI data 
bus. When the transfer is from Target to Initiator, 
DBR is set when a byte is received over the SCSI 
data bus and transferred into the DATA register 
and is reset by reading the DATA register. DBR 
is also reset whenever a Transfer Info command 
is issued. 

There are several causes of a Transfer Info com- 
mand completion/termination in addition to a 
reset. Just as for a Send or Receive command, 
the Transfer Info command can be terminated by 
issuing a subsequent Disconnect command, 
causing an immediate disconnect but no interrupt. 

A Transfer Info command will either complete or 
pause when the specified number of bytes (either 
a single byte or multiple bytes as defined by the 
SINGLE-BYTE TRANSFER bit in the COMMAND 
register) has been sent or received. The 33C92A 
generates a "successful completion" interrupt only 
after receiving another REQ from the Target 
during non-Message-ln information phases but 
generates a "paused/aborted" interrupt for Mes- 
sage-In phases without waiting for an additional 
REQ (Note that when the completed Transfer Info 
command was a Message-In transfer phase, the 
ACK pin will be left asserted by the 33C92A in the 
last REQ/ACK cycle of the command, and the 
processor is required to issue a Negate ACK or 
an Assert ATN followed by a Negate ACK com- 
mand to accept or reject the message). 

If a parity error is detected on a data byte 
received from the SCSI bus (and HSP=1 ) or on a 
data byte byte received from the host (and 
HHP=1), then the 33C92A will terminate the com- 
mand and, for SCSI parity errors, will leave ACK 
asserted (to also halt the Target). In this case a 
"terminated" interrupt is generated. Finally, a 
negation of the BSY- signal (i.e. the Target 
suddenly disconnects) or a transition in the I/O-, 
C/D-, and/or MSG pins during a Transfer com- 
mand will also terminate the command and 
generate a "terminated" interrupt. 
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If a parity error is detected on a received byte but 
parity error command termination is disabled 
(HSP=0 or HHP=0, as appropriate), the 33C92A 
will still set the PARITY ERROR status bit in the 
AUXILIARY STATUS register but will not ter- 
minate the command as a result of this error. 



7.5.7 Translate Address (18 hex) 

The Translate Address command performs a logi- 
cal-address to physical-address translation. Cer- 
tain SCSI commands involve a logical address 
which may be up to 32 bits in length. When a 
command is detected which requires address 
translation, the processor can load the logical ad- 
dress into the 33C92A LOGICAL ADDRESS 
register and then issue the Translate Address 
command to have the 33C92A do the conversion. 
Upon receiving a "successful completion" inter- 
rupt, the processor can read the CYLINDER 
NUMBER, HEAD NUMBER, and SECTOR NUM- 
BER registers to extract the logical address. The 
disk parameters contained in the TOTAL SEC- 
TORS, TOTAL HEADS, and TOTAL CYLINDERS 
registers must also be valid before issuing a 
Translate Address command. 

If automatic compensation for spare sectors is to 
be performed by the WD33C92A, then the num- 
ber of spare sectors per cylinder and total number 
of sectors per cylinder must also be loaded, 
respectively, into the HEAD NUMBER and 
CYLINDER NUMBER registers. A "terminated" in- 
terrupt will occur if any division operation per- 
formed during this command results in an over- 
flow. 



7.6 COMBINATION LEVEL II COMMANDS 



7.6.1 Select-and-Transfer (08 and 09 hex) 

The Select-and-Transfer commands greatly 
reduce the host or local processor interrupt-han- 
dling burden by enabling the 33C92A's internal 
microprocessor to manage the low-level SCSI 
protocol, resulting in as few as one interrupt per 
SCSI operation. Select-and-Transfer commands 
are used when in an Initiator role, and typically 
consist of at least the following SCSI phases: 

1 . Selection of a Target device. 

2. Sending of a command. 



3. Reception of status information. 

4. Reception of a COMMAND COMPLETE 
Message. 

These commands optionally consist of a Data 
Transfer phase and additional Message Transfer 
phases. 

The 33C92A will update the COMMAND PHASE 
register as the Select-and-Transfer command ex- 
ecutes. Upon completion or termination of the 
command, the local processor can read this 
register to determine where the SCSI operation 
stopped. 

The two Select-and-Transfer commands differ 
from each other only by whether or not the ATN 
pin is asserted during the Selection phase. The 
ability to assert ATN during Selection supports the 
SCSI Message Protocol which calls for an IDEN- 
TIFY Message Out phase following the Selection. 
When executing a Select W/ATN-and-Transfer 
commands, the 33C92A expects the Target to 
request a Message Out phase immediately follow- 
ing selection, whereas for a Select W/O ATN-and- 
Transfer command, it expects the Target to direct- 
ly enter Command phase. The Select-and-Trans- 
fer commands, moreover, support Group (6-byte 
CDB), Group 1 (10-byte CDB), and Group 5 (12- 
byte CDB) SCSI commands. 

When a Select-and-Transfer command is issued, 
the 33C92A arbitrates for the bus and selects a 
Target just as during a Select command. If the 
Target does not respond before a timeout occurs, 
the Select-and-Transfer command halts and a 
"terminated" interrupt is generated. Failure to 
complete the Selection phase is also indicated by 
the fact that the COMMAND PHASE register con- 
tains all zeros. If the Selection is successful, no 
interrupt is generated, but the COMMAND 
PHASE register will be set to a hex 1 0. 

After completing the Selection phase, the 33C92A 
begins an information transfer phase. If ATN has 
been asserted (i.e. a Select W/ATN-and-Transfer 
command was issued), the 33C92A expects 
the Target to respond with a Message Out phase. 
If the first information phase request is other than 
a Message Out request, the 33C92A will ter- 
minate the command and generate a "terminated" 
interrupt. However, when the Target does request 
a Message Out phase, the 33C92A will respond 
by automatically sending an IDENTIFY Message. 
This single byte message is of the binary 
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form: 1 rOOOttt, where r=1 if the ENABLE 
RESELECTION bit in the SOURCE ID register is 
equal to 1, and ttt is the encoded Target 
LOGICAL UNIT NUMBER contained in the TAR- 
GET LUN register. Once the IDENTIFY Message 
has been sent, the 33C92A will set the COM- 
MAND PHASE register to hex 20. 

Following the Message Out phase (or Selection 
phase when ATN was not asserted during Selec- 
tion), a Command phase is expected by the 
33C92A. Again, and throughout the entire Select- 
and-Transfer command execution, if the Target re- 
quests an unexpected information phase type, the 
33C92A terminates the command and generates 
a "terminated" interrupt. If the Command 
phase is requested in this situation, the 33C92A 
will extract the SCSI command from the internal 
COMMAND DESCRIPTOR BLOCK registers 
and send the 6-, 10-, or 12-bytes of command 
information as determined by its evaluation of the 
SCSI command code in the CDB1 register. The 
COMMAND PHASE register is set to hex 30 
before the first Command byte is sent and then 
increments with each byte transferred, so that for 
a 12-byte CDB command the COMMAND PHASE 
register will contain hex 3C when all bytes of the 
CDB have been transferred. 

After the Command phase, the 33C92A expects 
either a Data In phase, Data Out phase, Status 
phase, or Message In phase. If the Target is re- 
questing a Message In phase, a pending discon- 
nection is assumed. The 33C92A therefore ex- 
pects to receive either a Save-Data-Pointer mes- 
sage (hex 02) or a Disconnect message (hex 04). 
If either message is incorrect, or if a different mes- 
sage is received, a "terminated" interrupt will be 
generated to alert the processor of that fact and to 
allow the message to be read from the DATA 
register. A "terminated" interrupt will also be 
generated if the Target disconnects before 
sending the Disconnect message. When a correct 
Save-Data-Pointer message is received, a 
"paused/aborted" interrupt is generated and the 
Select-and-Transfer command terminated to allow 
the processor to save the SCSI data pointer. 
However, if a Disconnect message is received, 
the COMMAND PHASE register will be updated 
to hex 42 and command execution continues. 

When the actual Target-disconnection does occur, 
the COMMAND PHASE register is updated to hex 
43 and if the IDI bit is set, the WD33C92A ter- 
minates the Select-and-Transfer command by 



generating an 85H interrupt. However, if the IDI bit 
is reset, then instead the WD33C92A sits in an 
idle state, waiting for the Target to reconnect. If a 
different Target device Reselects the 
33C92A, a "terminated" interrupt is generated. 
However, if the original Target Reselects the 
33C92A, no interrupt is generated and the COM- 
MAND PHASE register is set to hex 44. 

Following the original Target Reselection, the 
33C92A expects a Message In phase which 
should consist of the Target sending an IDENTIFY 
Message. This single-byte message should be 
of the binary form: 1 0OOOttt, where ttt is the Target 
LUN. If the data received by the 33C92A is dif- 
ferent or the Target LUN specified in this byte 
does not match the contents of the TARGET 
LUN register, a "terminated" interrupt is generated 
and the Message byte may be examined by the 
processor. A correct IDENTIFY Message In phase 
results in the COMMAND PHASE register being 
updated to hex 45. 

After the IDENTIFY Message is received from the 
Target or immediately after the Command Out 
phase (when there is no disconnection), a Data In 
phase, Data Out phase, or Status phase 
should occur. If the TRANSFER COUNT register 
contains any non-zero value, then the 33C92A will 
expect a Data Transfer phase. If Advanced Fea- 
tures are enabled, then the DPD bit will be ex- 
amined to verify the correct data direction. If the 
data direction is incorrect, then a "terminated" in- 
terrupt is generated. In this phase, the 33C92A 
will use the TRANSFER COUNT register to 
determine the number of bytes to be transferred, 
and all host-side DATA register accesses will be 
accomplished via the method selected by the 
DMA mode select bits in the CONTROL register. 
When the internal counter reaches zero, the Data 
Transfer phase is complete and the COMMAND 
PHASE register is set to hex 46. 

Any number of disconnection/reconnection cycles 
may occur during the Data Transfer phase so long 
as they are accomplished according to the 
defined message protocol. The COMMAND 
PHASE register will cycle through the disconnect 
phases (41-45) with each disconnection and sub- 
sequent reconnection until all of the data has 
been transferred and the Data Transfer phase is 
complete. 

A Status phase is expected by the 33C92A follow- 
ing the Data Transfer phase (or instead of the 
Data Transfer phase when the TRANSFER 
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COUNT register contains a value of zero). At the 
start of the Status phase, the COMMAND PHASE 
register is loaded with hex 47. Upon completion of 
the Status phase, the COMMAND PHASE 
register will be updated to hex 50, and the 
received status byte is stored in the TARGET LUN 
register where it can be read upon completion of 
the command. 

Following completion of the status-byte transfer, a 
Message In phase is expected. The 33C92A ex- 
pects the Target to send a COMMAND COM- 
PLETE Message (hex 00) to indicate that the 
SCSI command operation has been completed. 
After the 33C92A receives this COMMAND COM- 
PLETE Message, the COMMAND PHASE 
register advances to hex 60, and if the EDI bit is 
reset, a "successful completion" interrupt is 
generated. The processor should then read the 
TARGET LUN register to examine the Target 
status. An additional interrupt will then occur when 
the SCSI bus goes to the Bus Free state, or when 
another REQ is asserted to begin an information 
transfer phase (as in SCSI linked commands). If 



the EDI bit is set, the "successful completion" in- 
terrupt will be suppressed until the Target discon- 
nects from the SCSI bus. 

At any time during execution of the Select-and- 
Transfer commands, an abnormal or unexpected 
condition will cause the 33C92A to terminate the 
command, set the appropriate status 
qualifiers, and generate a "terminated" interrupt. 
If the termination occurred during an information 
transfer phase, the 33C92A will be left in a Con- 
nected-as-an-lnitiator state (unless termination 
was due to a sudden Target disconnection). 
Command termination during any other phase will 
result in the 33C92A being in a Disconnected 
state. Transfer commands may be used to 
handle the exception by transferring messages 
with the Target. 

The following table summarizes the possible 
values that the COMMAND PHASE register can 
take during the Select-and-Transfer commands, 
and their meanings relative to command termina- 
tion: 



COMMAND 
PHASE 


MEANING 


00 


No SCSI bus device has been selected. The 33C92A is in the disconnected state. 


10 


The Target has been selected. The 33C92A is now in the connected as an Initiator 
state. 


20 


An Identify message has been sent to the Target. 


30 


Command phase has started, no bytes transferred. 


3x 


Command phase, x bytes have been transferred. 


41 


Save-Data-Pointer message received. 


42 


Disconnect message received, bus not free. 


43 


Target has disconnected (SCSI bus free) following a successful transfer of a Discon- 
nect message. The 33C92A is now in the disconnected state. 


44 


The 33C92A has been reselected by the Target whose SCSI bus ID matches the value 
in the DESTINATION ID register. The 33C92A is now in the connected as an Initiator 
state. 


45 


The 33C92A has received an Identify message from the Target whose Logical Unit 
Number matches the value in the TARGET LUN register. 


46 


The number of bytes specified in the TRANSFER COUNT register have been trans- 
ferred to/from the Target during a Data Out/In phase. 


47 


The Target has begun a Receive Status phase. 


50 


The 33C92A has successfully received a Status byte from the Target and stored it in 
the TARGET LUN register. 


60 


The 33C92A has successfully received a Command Complete message from the Tar- 
get. 
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A "Resume Select-and-Transfer" command is as- 
sumed whenever a normal "Select-and-Transfer" 
command is issued while the 33C92A is in the 
Connected-As-An-lnitiator state. When the 
"Resume" is issued, the 33C92A examines the 
COMMAND PHASE register to determine where 
to restart the Select-and-Transfer command ex- 
ecution. This feature, in conjunction with the IN- 



TERMEDIATE DISCONNECT INTERRUPT 
enabled, allows support of multi-threaded or over- 
lapped I/O on the SCSI bus. 

The following table briefly describes the valid set- 
tings of the COMMAND PHASE register when 
resuming a Select-and-Transfer command: 



COMMAND 
PHASE 



MEANING 



10 



Resume after Target selection is complete. 



20 



Resume after Identify message out. Command phase is expected; an implied Negate 
ACK occurs. 



30 



Resume when Command phase has begun (REQ asserted). 




41 



Resume after Command phase or after Save-Data-Pointer message. Data, Status, or 
Message In phases are expected. An implied Negate ACK occurs. 



42 



Resume to complete Disconnect Message In; an implied Negate ACK occurs. 



44 



Resume after reselection by a Target. 



45 



Resume to transfer more data in a data transfer phase. May expect Status or Message 
In as well. An implied Negate ACK occurs. 



46 



Resume after the data has has been completed, expecting Status phase or a Save- 
Data-Pointer/Disconnect Message In phase. An implied Negate ACK does NOT occur. 
Resume to complete a Status phase; an implied Negate ACK occurs. 



50 



Resume to complete a Command Complete message from the Target; an implied 
Negate ACK occurs. 



60 
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7.6.2 Reselect-and-Transfer (OA and OB hex) 

The Reselect-and-Transfer commands include the 
Reselect-and-Receive-Data and the Reselect- 
and-Send-Data commands. These commands 
cause the 33C92A to execute certain common 
SCSI bus phase sequences as a Target following 
a Reselection phase. These phases are deter- 
mined by which command is sent, and the setting 
of two bits: the EDI bit in the CONTROL register; 
and the SCC bit in the DESTINATION ID register. 
The SCSI bus phase sequences are summarized 
below. 

Refer to the command descriptions of the Send- 
Status-and-Command-Complete and Send-Dis- 
connect-Message commands for details on those 
sequences. 

1. Reselect-and-Receive command, EDI=0, 
and SCC=don't care: 

- Reselection phase; 

- Send Identify Message In; 

- Receive Data Out phase; 

- Completion interrupt. 

2. Reselect-and-Send command, EDI=0, and 
SCC=don't care: 

- Reselection phase; 

- Send Identify Message In; 

- Send Data In phase; 

- Completion interrupt. 

3. Reselect-and-Receive command, EDI=1, 
and SCC=0: 

- Reselection phase; 

- Send Identify Message In; 

- Receive Data Out phase; 

- Chain to Send-Status-and-Command 
Complete; 



4. Reselect-and-Send command, EDI=1, and 
SCC=0: 

- Reselection phase; 

- Send Identify Message In; 

- Send Data In phase; 

- Chain to Send-Status-and-Command- 
Complete; 

5. Reselect-and-Receive command, EDI=1, 
and SCC=1 : 

- Reselection phase; 

- Send Identify Message In; 

- Receive Data Out phase; 

- Chain to Send-Disconnect-Message; 

6. Reselect-and-Send command, EDI=1, and 
SCC=1: 

- Reselection phase; 

- Send Identify Message In; 

- Send Data In phase; 

- Chain to Send-Disconnect-Message; 

If the reselection attempt times out during a 
Reselect-and-Transfer command, ATN is asserted 
and HA=1, or if a parity error is detected on a 
incoming data byte (and HSP=1 or HHP=1, 
depending on data direction), the command will 
be terminated and the appropriate status will be 
set. In this case, the COMMAND 

PHASE register should be evaluated to determine 
the last successfully completed phase. If none of 
these conditions occurs, all phases complete nor- 
mally, and if EDI=0, then a "successful comple- 
tion" interrupt would be generated at this point. 
However, if EDI=1, no interrupt is generated and 
command chain occurs (as described above). 
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The following table summarizes the possible 
values that the COMMAND PHASE register can 
take during the Reselect-and-Transfer com- 
mands, and their meanings relative to command 
termination. See other command descriptions for 
additional values that can occur when command 
chaining is used. 



amines the COMMAND PHASE register to 
determine where to restart the Reselect-and- 
Transfer command execution. This feature, in 
conjunction with the capability to chain to other 
combination commands, allows longer SCSI bus 
sequences to be executed by a single command. 



COMMAND 
PHASE 


MEANING 


00 


No SCSI bus device has been reselected. The 33C92A is in the disconnected state. 


10 


The 33C92A has successfully reselected the Initiator. The 33C92A is now in the con- 
nected as a Target state. 


20 


The Identify message has been successfully sent to the Initiator. 


46 


The requested datajransfer has been completed. 



A "Resume Reselect-and-Transfer" command is 
assumed whenever a normal "Reselect-and- 
Transfer" command is issued while the 
33C92A is in the Connected-as-a-Target state. 
When the "Resume" is issued, the 33C92A ex- 



The following table briefly describes the meaning 
of the COMMAND PHASE register when resum- 
ing a Reselect-and-Transfer command: 




COMMAND 
PHASE 


MEANING 


10 


Resume after Initiator reselection is complete; start with Identify Message Out. 


20 


Resume after Identify message out; start with data transfer phase. If TRANSFER 
COUNT is zero, no data transfer phase occurs. In either case, a chain to another com- 
bination command can occur if enabled. 
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7.6.3 Wait-for-Select-and-Receive (OC hex) 

The Wait-for-Select-and-Receive causes the 
33C92A to idle until it is selected by an Initiator, at 
which time the 33C92A will enter the Target mode 
and message and command information will auto- 
matically be requested. As an option, the 33C92A 
may be programmed to disconnect when a SCSI 
read command is received while executing a 
Wait-for-Select-and-Receive command. Use of 
this command therefore eliminates the interrupts 
which normally occur after selection and after 
each subsequent SCSI bus phase, and results in 
very short bus-connect time during SCSI read 
commands. 

If ATN was asserted by the Initiator during the 
selection phase, the 33C92A will first execute an 
implied "Receive Message Out" command to get 
the Identify message from the Initiator, before 
continuing on with the implied "Receive Com- 
mand" to receive the SCSI command information. 
The SCSI command information (CDB) will be 
stored in the CDB registers (hex addresses 03 to 
0E), and if a valid IDENTIFY message is received, 
it will be saved in the TARGET LUN register (hex 
address OF). The number of command bytes re- 
quested by the 33C92A is determined by the 
SCSI group code in the first byte of the CDB. 

After the 33C92A is selected and receives all valid 
command and message information, a "success- 
ful completion" interrupt will normally be 
generated to allow the local processor to read out 
and interpret the SCSI CDB. However, by setting 
the EDI bit prior to issuing a Wait-for-Select-and- 
Receive command, the 33C92A is enabled to per- 



form an automatic disconnect when a SCSI read 
command is received. Therefore, when EDI=1 
and the 1st CDB byte received contains a 6-, 10-, 
or 12-byte read command code, then the 33C92A 
will temporarily suppress the interrupt and chain 
to begin execution of a Send-Disconnect-Mes- 
sage command. An interrupt will then be 
generated after completion of this command, 
which normally would indicate a transition to the 
bus free condition. Refer to the Send-Disconnect- 
Message command description for more details. 

If during execution the message or command in- 
formation received from the Initiator is invalid, the 
implied receive command will be terminated and 
the appropriate status reported. In this case, the 
COMMAND PHASE register should be read to 
determine which phase of the Wait-for-Select- 
and-Receive command was last completed before 
the error condition occurred. A COMMAND 
PHASE hex value of hex 10 indicates that the 
33C92A was successfully selected. A hex value of 
20 indicates that a message was received from 
the Initiator, and when the 33C92A begins 
receiving command bytes, the COMMAND 
PHASE is set to hex 30 and increments with each 
byte received (to a maximum of 3C for a 12- 
byte CDB command). 

The following table summarizes the possible 
values that the COMMAND PHASE register can 
take during the Wait-for-Select-and-Receive com- 
mand, and their meanings relative to command 
termination. See other command descriptions for 
additional values that can occur when command 
chaining is used. 



COMMAND 
PHASE 


MEANING 


00 


The 33C92A has not been selected. The 33C92A is in the disconnected state. 


10 


The 33C92A has been successfully selected by the Initiator. The 33C92A is now in the 
connected as a Target state. 


20 


The Identify message has been successfully received from the Initiator. 


30 


The 33C92A has begun command phase by setting the SCSI bus phase signals and 
asserting REQ. 


31 


The 33C92A has transferred 1 command byte from the Initiator. The SCSI STATUS 
may indicate the need for the host to load the command size into the OWN ID 
register. 


3x 


The 33C92A has transferred x command bytes from the Initiator. 
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A "Resume Wait-for-Select-and-Receive" com- 
mand is assumed whenever a normal "Wait-for- 
Select-and-Receive" command is issued 
while the 33C92A is in the Connected-as-a-Target 
state. When the "Resume" is issued, the 33C92A 
examines the COMMAND PHASE register to 
determine where to restart the Wait-for-Select- 
and-Receive command execution. This feature, in 



conjunction with the capability to chain to other 
combination commands, allows longer SCSI bus 
sequences to be executed by a single command. 

The following table briefly describes the meaning 
of the COMMAND PHASE register when resum- 
ing a Wait-for-Select-and-Receive command: 



COMMAND 
PHASE 


MEANING 


10 


Resume after selection by the Initiator is complete; start with Identify Message Out if 
ATN is asserted, otherwise, start with command phase. 


20 


Resume after a message out; check the received message in the TARGET LUN 
register for a valid Identify message. 


30 


Resume after Identify message out. Start with command phase. 


31 


Resume after the 33C92A has transferred 1 command byte from the Initiator. This 
resume point is used only when an unknown group code has been detected in Ad- 
vanced Mode, and the command size has been loaded into the OWN ID register. 
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7.6.4 Send-Status-and-Command-Complete 
(OD hex) 

The Send-Status-and-Command-Complete com- 
mand is valid in the Target role, and is used to 
complete a SCSI operation by transferring the ap- 
propriate status information to the Initiator 
prior to disconnection from the SCSI bus. This 
command also supports linked SCSI operations 
by optionally allowing a linked command-com- 
plete message to be sent after the status is 
transferred. Linked command complete messages 
are controlled by the CDB12 register with bits that 
correspond to the standard linked command con- 
trol bits in the CDB. 

Before a Send-Status-and-Command-Complete 
command is issued, the CDB11 register must be 
loaded with a status byte which will then be trans- 
ferred across the SCSI bus. Also, the link control 
bits from the current CDB must be loaded into the 
CDB12 register to ensure that the correct se- 
quence occurs. 

The bits used by the 33C92A are identical in 
meaning to the SCSI standard link control bits. 
The host processor may simply load the control 
byte from the current SCSI command into CDB12 
to get the correct function. As the command ex- 
ecution progresses, the COMMAND PHASE 
register will be updated to indicate the last phase 
completed. 

The possible sequences caused by this command 
are as follows: 



1. CDB12 bitO=0, bit1=don't care: The status 
byte in CDB11 is sent, followed by a Com- 
mand Complete message (00 hex). A 
"successful completion" interrupt now oc- 
curs. 

2. CDB12 bit0=1, bit1=0: The status byte in 
CDB11 is sent, followed by a Linked Com- 
mand Complete message (0A hex). A 
chain to the command fetch portion of 
Wait-for-Select-and-Receive then occurs 
to fetch the next CDB from the Initiator. 
33C92A command execution proceeds as 
described for that command. 

3. CDB12 bit0=1, bit1=1: The status byte in 
CDB 11 is sent, followed by a Linked Com- 
mand Complete with Flag message (OB 
hex). A chain to the command fetch por- 
tion of Wait-for-Select-and-Receive then 
occurs to fetch the next CDB from the In- 
itiator. 33C92A command execution 
proceeds as described for that command. 

A Send-Status-and-Command-Complete com- 
mand may be terminated by ATN asserted when 
HA=1, or when a Disconnect or Reset command 
is issued. 

The following table summarizes the possible 
values that the COMMAND PHASE register can 
take during the Send-Status-and-Command-Com- 
plete command, and their meanings relative to 
command termination. See other command 
descriptions for additional values that can occur 
when command chaining is used. 



COMMAND 
PHASE 


MEANING 


00 


No operation occurred; typically, ATN was found to be asserted. 


50 


Status phase transfer completed. 


60 


Command Complete message transfer completed. 


61 


Linked Command Complete message transfer completed. 
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A "Resume Send-Status-and-Command-Com- 
plete" command is assumed whenever a normal 
"Send-Status-and-Command-Complete" com- 
mand is issued while the 33C92A is in the Con- 
nected-as-a-Target state. When the "Resume" is 
issued, the 33C92A examines the COMMAND 
PHASE register to determine where to restart the 
Send-Status-and-Command-Complete command 
execution. This feature, in conjunction with the 



capability to chain to other combination com- 
mands, allows longer SCSI bus sequences to be 
executed by a single command. 

The following table briefly describes the meaning 
of the COMMAND PHASE register when resum- 
ing a Send-Status-and-Command-Complete com- 
mand: 



COMMAND 
PHASE 



MEANING 



50 



Resume after status phase. Start with command complete message. May chain to 
command fetch if commanded to do so. 
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7.6.5 Send-Disconnect-Message (OE hex) 

The Send-Disconnect-Message command is a 
Target-role command which may be used to dis- 
connect from the SCSI bus at any time during a 
SCSI command sequence. This command con- 
sists of sending a Disconnect message byte, fol- 
lowed by physical disconnection from the bus 
(SCSI bus free). An interrupt is generated only 
after transition to bus free occurs. As an option, a 
Save-Data-Pointer message will automatically be 
sent before the Disconnect message whenever 
the IDI bit is set prior to issuing this command. 

The COMMAND PHASE register is updated 
during execution of the Send-Disconnect-Mes- 
sage command to indicate bus phase status. 
After a Save-Data-Pointer message is sent, the 



COMMAND PHASE will be set to 41 H. After the 
Disconnect message transfer, this register will be 
updated to 42H, and after disconnection the 
COMMAND PHASE register will contain a 43H. 

A Send-Disconnect-Message command may be 
terminated by ATN asserted when HA=1 , or when 
a Disconnect or Reset command is issued. 

The following table summarizes the possible 
values that the COMMAND PHASE register can 
take during the Send-Disconnect-Message, and 
their meanings relative to command termination. 
See other command descriptions for additional 
values that can occur when command chaining is 
used. 



COMMAND 
PHASE 


MEANING 


00 


No operation occurred; typically, ATN was found to be asserted. 


41 


The Save-Data-Pointer message was transferred. 


42 


The Disconnect message was transferred. 


43 


The bus free state occurred after the Disconnect message was transferred. The 
33C92A is now in the disconnected state. 
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8.0 DC ELECTRICAL SPECIFICATIONS 

8.1 MAXIMUM RATINGS 



Ambient temperature 
under bias 


0°C to 70°C 


Storage temperature 


-55° C to 125° C 


Voltage on any pin 
with respect to GND 


-0.5 to 7 Volts 


Power dissipation 


190 mW 


Input Static 
Discharge Protection 


2000 V pin to pin 



8.2 STANDARD TEST CONDITIONS 

The characteristics below apply for the following 
standard test conditions, unless otherwise noted. 
All voltages are referenced to Vss (0V Ground). 
Positive current flows into the referenced pin. 



Operating tempera- 
ture range 


0° to 70° C 


Vcc 


+5 Volts ± 0.25 V 


Vss 


Volts 



NOTE 

Stresses above those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to 
the device. This is a stress rating only and func- 
tional operation of the device at these or any other 
conditions above those indicated in the operation- 
al section of the specification is not implied. Ex- 
posure to absolute maximum rating conditions for 
extended periods may affect product reliability. 
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8.3 DC OPERATING CHARACTERISTICS 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


IlL 


Input Leakage 


— 


10 


UA 


Vin = .4 to VCC 


lOL 


Output Leakage 
(inactive) 


— 


50 


|LlA 


V UT = .4toVCC 


V| H 


Input High Voltage 


2.0 


— 


V 




V|L 


Input Low Voltage 


— 


0.8 


V 




VOH 


Output High Voltage 


2.4 


— 


V 


lo = -400 uA 


VOL1 


Output Low Voltage 
(TGS, IGS) 


— 


0.4 


V 


lo = 7.0 mA 


Voi_2 


Output Low Voltage 
(all others) 


— 


0.4 


V 


lo = 4.0 mA 


Ice 


Supply Current 


— 


36 


mA 


Ta = +25°C 
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9.0 AC OPERATING CHARACTERISTICS 

Timing characteristics are valid over the entire 

operating temperature (0 to 70 deg. C) and volt- Tcyc =Tcp * divisor/ 2 

age (4.75 to 5.25 Volts) ranges. All pins are refer- wher e: 

enced to and from a low voltage of 0.8 volts and a 

high voltage of 2.0 volts except for SCSI bus ^g^ffiSSVtPax** 

pins, Which are referenced to 1 .5 VOltS. All outputs DIVISOR is the clock divisor selected in the OWN ID register. 

are assumed to have a load capacitance of 50 

^ For example, with a 16MHz clock input to the 

Many of the timing parameters that follow are 33C92A, the clock divisor selected would be 4. 

defined in terms of an internal clock cycle time Therefore, the value of Tcyc would be: 

that is determined by the input clock and the clock 

divisor selected in the OWN ID register. This cycle T = 62 5 nsec M/ 2 = 125 nsec 

time is calculated as follows: 
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9.1 PROCESSOR/DMA INTERFACE 



9.1.1 CLK 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tcp 


CLOCK PERIOD 


50 


125 


ns 


tch 


CLOCK HIGH 


20 




ns 


tcl 


CLOCK LOW 


20 




ns 




FIGURE 9-1 . CLOCK TIMING 
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9.1.2 MR- 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tmr 


MR- PULSE WIDTH 


1 




\iS 




FIGURE 9-2. MR- TIMING 



23 
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9.1.3 Processor Write (Indirect Addressing) 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tavwl 


AO VALID TO WE- LOW 







ns 


tclwl 


CS- LOW TO WE- LOW 







ns 


twe 


WE- PULSE WIDTH 


120 




ns 


tdvwh 


DATA VALID TO WE- HIGH 


70 




ns 


twhai 


WE- HIGH TO AO INVALID 







ns 


twhch 


WE- HIGH TO CS- HIGH 







ns 


twhdi 


WE- HIGH TO DATA INVALID 







ns 


twhwl 


WE- HIGH TO WE- OR RE- LOW 


100 




ns 



AO 

CS 

WE 

D0-D7, DP 










— ^j tyVHAI 








~ *AVWL 






-*^ 


i 






I 


>-: 


tCLWL 






— *4 ^HCH 


-< 


\l 


/ 


rHWL- 


\ 










"te ' ^ t\A 


^ Wc 


"^^\ ^ w 








\ 


J , 




i 




i^ U,mn, 


> i < 'WHDI 




; -^. uv vvii 








I 


)( 





FIGURE 9-3. PROCESOR WRITE (INDIRECT ADDRESSING) TIMING 
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9.1 .4 Processor Read (Indirect Addressing) 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tavrl 


AO VALID TO RE- LOW 







ns 


tclrl 


CS- LOW TO RE- LOW 







ns 


tre 


RE- PULSE WIDTH 


180 


10000 


ns 


trldv 


RE- LOW TO DATA VALID 


— 


180 


ns 


trhch 


RE- HIGH TO CS- HIGH 







ns 


trhdi 


RE- HIGH TO DATA INVALID 


5 


40 


ns 


trhrl 


RE- HIGH TO RE- OR WE- LOW 


100 




ns 


trhai 


RE- HIGH TO AO INVALID 







ns 



A0 

CS 

RE 

D0-D7, DP 


i-< 










>1 l RHAI 






" *AVRL 






•^ 


i 






i 


>►: 


l CLRL 




-< 




*4 ^HCH 


-< 


\) 


i / 


"" ■ 

1HRL- 


1 










W 


^ * : <r f r 




RE 


j^-\ ^ i 






^LDV- 


\ 

—>- 


-J , 




i 




'^- 


l^ l RHDI w 












I 


i 






FIGURE 9-4. PROCESSOR READ (INDIRECT ADDRESSING) TIMING 
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9.1 .5 Processor Write (Direct Addressing) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


taval 


ADDR VALID TO ALE LOW 


40 




ns 


talai 


ALE LOW TO ADDR INVALID 







ns 


talwl 


ALE LOW TO WE- LOW 


90 




ns 


tclwl 


CS- LOW TO WE- LOW 







ns 


twe 


WE- PULSE WIDTH 


120 




ns 


tdvwh 


DATA VALID TO WE- HIGH 


70 




ns 


twhch 


WE- HIGH TO CS- HIGH 







ns 


twhdi 


WE- HIGH TO DATA INVALID 







ns 


twhwl 


WE- HIGH TO WE- OR RE- LOW 


100 




ns 


tahal 


ALE HIGH TO ALE LOW 


— 


1 


us 



w • t A Ul A 1 ■' — r 








^\ AnAL :^v 




j ^i l CLWL i-* 


>~ 


tWHCH '**- 


GS ■;- j \: | 


r~ 


\ 








j"^ l ALWL ^i^ 


l WE ^ 

/ 


"^ l WHwL *~\ 


WE j \ 




\ 


^ l AVAL : l ALAI l* 


H< l DVWH >- 


-< l WHDI >*j 


»»• - J ™— wrnm x 



FIGURE 9-5. PROCESSOR WRITE (DIRECT ADDRESSING) TIMING 
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9.1 .6 Processor Read (Direct Addressing) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


taval 


ADDR VALID TO ALE LOW 


40 




ns 


talai 


ALE LOW TO ADDR INVALID 







ns 


talrl 


ALE LOW TO RE- LOW 


30 




ns 


tclrl 


CS- LOW TO RE- LOW 







ns 


tre 


RE- PULSE WIDTH 


180 


10000 


ns 


trldv 


RE- LOW TO DATA VALID 




180 


ns 


trhch 


RE- HIGH TO CS- HIGH 







ns 


trhdi 


RE- HIGH TO DATA INVALID 


5 


40 


ns 


trhrl 


RE- HIGH TO RE- OR WE- LOW 


100 




ns 


tahal 


ALE HIGH TO ALE LOW 




1 


us 



-►^AHALJ- 



-J~l 



tCLRL 



RHCH 



CS 



RE 



ALRL- 



> ■ ; « < 



X RE 



>:< 



J~\ 



RHRL- 



7WAL i 



T ALAI 



I 



RLDV 



r RHDI 



D0-D7, DP 



DC 



ADDRESS 



FIGURE 9-6. PROCESSOR READ (DIRECT ADDRESSING) TIMING 
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9.1.7 DMA Write 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tdlwl 


DACK- LOW TO WE- LOW 







ns 


tdlqh 


DACK- LOW TO DRQ- HIGH 




75 


ns 


twr 


WE- PULSE WIDTH 


50 




ns 


twhwl 


WE- HIGH TO WE- LOW 


100 




ns 


tdvwh 


DATA VALID TO WE- HIGH 


25 




ns 


twhdh 


WE- HIGH TO DACK- HIGH 







ns 


twhdi 


WE- HIGH TO DATA INVALID 







ns 


tdhql 


DACK- HIGH TO DRQ- LOW 







ns 



DRQ (OUT) \ 


^LC 


)H 


— H 




-<— ^HQL- 




/ 




-< 


\: 


>-| 


l DLWL 




>- 


tWHDH 




DACK (IN) V| 






/ 


tWHWL - 


\ 




^ ti.,n ^ 






VVI I -»- 

/ 






WE 




\ 




i 






-*H bv-WH>- 


-< tWHDI 


^— 


D0-D7, DP 






X X 





FIGURE 9-7. DMA WRITE 
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9.1.8 DMA Read 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tdlrl 


DACK-LOWTORE-LOW 







ns 


tdlqh 


DACK- LOW TO DRQ- HIGH 




75 


ns 


trd 


RE- PULSE WIDTH 


80 




ns 


trhrl 


RE- HIGH TO RE- LOW 


100 




ns 


trldv 


RE- LOW TO DATA VALID 




70 


ns 


trhdh 


RE- HIGH TO DACK- HIGH 







ns 


trhdi 


RE- HIGH TO DATA INVALID 


5 


40 


ns 


tdhql 


DACK- HIGH TO DRQ- LOW 







ns 




DRQ~ (OUT) \ 




E ^LQH — >-: 




-*— ^HQL — H 


/ 




-< 


V 


— >-: 


tQLRL ** 


>~ 


l RHDH 




DACK (IN) 


\l 


/ 


t O UD 1 


\ 


■ ^ ton 






;-^t nU ■■ 


1 






RE 




\i 




i_ 






>"! *RLDV :"< 




tRHDI i^ 


D0-D7, DP 




i 


\ 


< 













FIGURE 9-8. DMA READ TIMING 
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9.1.9 Bus Buffer Write 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tqhsl 


DRQ HIGH TO RCS- LOW 





40 


ns 


tslwv 


RCS- LOW TO WE- VALID 


-5 


20 


ns 


two 


WE- PULSE WIDTH 


1-20ns 




Tcyc 


twldv 


WE- LOW TO DATA VALID 




50 


ns 


twhdl 


WE- HIGH TO DATA INVALID 


10 




ns 


twhwl 


WE- HIGH TO WE- LOW 


1-20ns 




Tcyc 


tqlsh 


DRQ LOW TO RCS- HIGH 


8 


10 


Tcyc 


tshwi 


RCS- HIGH TO WE- INVALID 




100 


ns 


twhsh 


WE- HIGH TO RCS- HIGH 







ns 


tslwl 


RCS- LOW TO WE- LOW 


60 




ns 


tqlwl 


DRQ LOW TO WE- LOW (1 ) 







ns 


tslql 


RCS- LOW TO DRQ LOW (2) 




100 


ns 



(1) Guarantees that only one more byte will be 
transferred. 



(2) Guarantees that only one byte will be trans- 
ferred. 



>H 

DRQ (IN) __/ 


tQHSL 


*W ^ toi r\\ 


^: ^ \r\\ on >^: 




^■j^. oLUL 












\j 




!-«— ! SLWL — ► 




— *H l QLWL 


-<— *-! ^HWI 


-< 
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WE (OUT) — 
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> : *SLWV ■ < 


^ *wo 
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FIGURE 9-9. BUS BUFFER WRITE TIMING 
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9.1.10 Bus Buffer Read 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tqhsl 


DRQ HIGH TO RCS- LOW 





40 


ns 


tslrv 


RCS- LOW TO RE- VALID 


-5 


20 


ns 


tro 


RE- PULSE WIDTH 


1-20ns 




Tcyc 


tdvrh 


DATAVALIDTORE-HIGH 


20 




ns 


trhdi 


RE- HIGH TO DATA INVALID 







ns 


trhrl 


RE- HIGH TO RE- LOW 


1-20ns 




Tcyc 


tqlsh 


DRQ LOW TO RCS- HIGH 


8 


10 


Tcyc 


tshri 


RCS- HIGH TO RE- INVALID 




100 


ns 


trhsh 


RE- HIGH TO RCS- HIGH 







ns 


tslrl 


RCS- LOW TO RE- LOW 


60 




ns 


tqlrl 


DRQ LOW TO RE- LOW (1) 







ns 


tslql 


RCS- LOW TO DRQ LOW (2) 
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ns 




(1) Guarantees that only one more byte will be 
transferred. 



(2) Guarantees that only one byte will be trans- 
ferred. 
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9.1.11 Burst DMA Write 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tdlwl 


DACK- LOW TO WE- LOW 







ns 


twlqh 


WE- LOW TO DRQ- HIGH 
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ns 


twr 


WE- PULSE WIDTH 
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ns 


twhwl 


WE- HIGH TO WE- LOW 
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ns 
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DATA VALID TO WE- HIGH 
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ns 
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9.1.12 Burst DMA Read 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tdlrl 


DACK- LOW TO RE- LOW 







ns 


trlqh 


RE- LOW TO DRQ- HIGH 




75 


ns 


trd 


RE- PULSE WIDTH 
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ns 


trhrl 


RE- HIGH TO RE- LOW 
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ns 


trldv 


RE- LOW TO DATA VALID 
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9.1.13 INTRQ 


SYMBOL 


CHARACTERISTIC 


MIN 
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UNITS 


tihrl 


INTRQ HIGH TO RE- LOW 







ns 
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RE- PULSE WIDTH 
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9.2 SCSI INTERFACE 



9.2.1 Arbitration 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tblel 


BSYI, SELI LOW TO SDIE LOW 


4 




Tcyc 


tello 


SDIE LOW TO BUS ID OUT 






Tcyc 
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BUSIDOUTTOARBLDHIGH 






Tcyc 


tahdf 


ARBLD HIGH TO DATA FLOAT 






Tcyc 


tdfeh 


DATA FLOAT TO SDIE, SDOE HIGH 






Tcyc 


tblbh 


BSYI, SELI LOW TO BSYO HIGH 


12 


17 


Tcyc 


tbheh 


BSYO HIGH TO SDIE, SDOE HIGH 





200 


ns 


tbhsh 


BSYO HIGH TO SELO HIGH 


2.2 




|LIS 



NOTE: 

I/O* = I/O, C/D, MSG, REQ; ATN* = ATN, ACK 
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9.2.2 Selection (Initiator) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tshel 


SELO HIGH TO SDIE LOW 


1.2 




us 


teloo 


SDIE LOW TO "OR-ED" ID OUT 


100 




ns 


tovgh 


"OR-ED" ID OUT VALID TO IGS HIGH 


100 




ns 


taogh 


ATN, ACK OUT TO IGS HIGH 


100 




ns 


tghav 


IGS HIGH TO ATN VALID 


400 




ns 


tavbl 


ATN, ACK VALID OUT TO BSYO LOW 


100 




ns 


tblbv 


BSYO LOW TO BSY HIGH VALID 


400 




ns 


tbhsl 


BSYI HIGH TO SELO LOW 


100 




ns 



NOTE: 

I/O* = I/O, C/D, MSG, REQ; SDIE* = SDIE, 

ARBLD 
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9.2.3 Selection (Target) 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tshbl 


SELI HIGH TO BSYI LOW 







ns 


tivbl 


"OR-ED" ID VALID IN TO BSYI LOW 







ns 


tblbh 


SELI HIGH, ID VALID, BSYI LOW TO 
BSYO HIGH 


0.4 


200 


l^ s 


tbhoi 


BSYO HIGH TO "OR-ED" ID INVALID IN 







ns 


tbhsl 


BSYO HIGH TO SELI LOW 







ns 


tavsl 


ATN VALID IN TO SELI LOW 







ns 


tslio 


SELI LOW TO I/O OUT 


100 




ns 


tivgh 


I/O OUT VALID TO TGS HIGH 


100 




ns 



NOTE: 

I/O* = I/O, C/D, MSG, REQ; SDOE* = SDOE, 

ARBLD 
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9.2.4 Reselection (Target) 



SYMBOL 


CHARACTERISTIC 
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UNITS 


tshel 


SELO HIGH TO SDIE LOW 


1.2 




|LIS 


teloo 


SDIE LOW TO "OR-ED" ID OUT 


100 




ns 


tovgh 


"OR-ED" ID OUT VALID TO IGS HIGH 


100 




ns 


taogh 


ATN, ACK OUT TO IGS HIGH 


100 




ns 


tghav 


IGS HIGH TO ATN VALID 


400 




ns 


tavbl 


ATN, ACK VALID OUT TO BSYO LOW 


100 




ns 


tblbv 


BSYO LOW TO BSY HIGH VALID 


400 




ns 


tbhsl 


BSYI HIGH TO SELO LOW 


100 




ns 



NOTE: 

C/D* = C/D, MSG, REQ; ATN* = ATN, ACK; SDIE* 

= SDIE,ARBLD 
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9.2.5 Reselection (Initiator) 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tshbl 


SELIHIGHTOBSYILOW 







ns 


tivbl 


"OR-ED" ID VALID IN TO BSYI LOW 







ns 


tihbl 


I/O IN HIGH TO BSYI LOW 







ns 


tblal 


SELI HIGH, ID VALID, BSYI LOW TO 
ATN LOW 







ns 


tghao 


IGSHIGHTOATNOUT 


100 




ns 


talgh 


ATN LOW TO IGS HIGH 


400 




ns 


tihbh 


IGS HIGH TO BSYO HIGH 


100 




ns 


tblbh 


BSYI LOW TO BSYO HIGH 


0.4 


200 


ns 


tbhol 


BSYO HIGH TO "OR-ED" INVALID IN 







ns 


tbhsl 


BSYO HIGH TO SELI LOW 







ns 


tslbl 


SELI LOW TO BSYO LOW 







ns 



NOTE: 

ATN* = ATN, 
SELO; 



ACK; SDOE* = SDOE, ARBLD, 
C/D* = C/D, MSG, REQ 
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9.2.6 Asynchronous Information Transfer In 
(Initiator) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tslpc 


SELI LOW TO PHASE CHANGE IN 







ns 


tihol 


I/O IN HIGH TO SDOE LOW, DATA BUS 
TRISTATE 





125 


ns 


tdtih 


DATA BUS TRISTATE TO SDIE HIGH 


-10 




ns 


tpcrh 


PHASE CHANGE IN TO REQ IN HIGH 


350 




ns 


tdvrh 


DATA VALID IN TO REQ IN HIGH 







ns 


trhah 


REQ IN HIGH TO ACK OUT HIGH 





175 


ns 


tahrl 


ACK OUT HIGH TO REQ IN LOW 







ns 


trial 


REQ IN LOW TO ACK OUT LOW 





175 


ns 


tahdi 


ACK OUT HIGH TO DATA INVALID IN 







ns 
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9.2.7 Asynchronous Information Transfer In 
(Target) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tslpc 


SELI LOW TO PHASE CHANGE OUT 


100 




ns 


tihil 


I/O OUT HIGH TO SDIE LOW 







ns 


tiloh 


SDIE LOW TO SDOE HIGH, DATA OUT 


30 




ns 


tdvrh 


DATA OUT VALID TO REQ OUT HIGH 


80 




ns 


tpcrh 


PHASE CHANGE OUT TO REQ OUT 
HIGH 


500 




ns 


trhah 


REQ OUT HIGH TO ACK IN HIGH 







ns 


tahrl 


ACK IN HIGH TO REQ OUT LOW 





175 


ns 


tahdl 


ACK IN HIGH TO DATA OUT INVALID 







ns 


trial 


REQ OUT LOW TO ACK IN LOW 







ns 


talpc 


ACK IN LOW TO PHASE CHANGE OUT 
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ns 



NOTE: C/D* = C/D, MSG 
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9.2.8 Asynchronous Information Transfer 
Out (Initiator) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tslpc 


SELI LOW TO PHASE CHANGE IN 







ns 


tilil 


I/O IN LOW TO SDIE LOW 







ns 


tiloh 


SDIE LOW TO SDOE HIGH, DATA OUT 


30 




ns 


tpcrh 


PHASE CHANGE IN TO REQ IN HIGH 


350 




ns 


trhah 


REQ IN HIGH TO ACK OUT HIGH 





175 


ns 


tdvah 


DATA OUT VALID TO ACK OUT HIGH 


80 




ns 


tahrl 


ACK OUT HIGH TO REQ IN LOW 







ns 


trial 


REQ IN LOW TO ACK OUT LOW 





175 


ns 


trldi 


REQ IN LOW TO DATA OUT INVALID 







ns 


talpc 


ACK OUT LOW TO PHASE CHANGE IN 
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9.2.9 Asynchonous Information Transfer Out 
(Target) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tslpc 


SELI LOW TO PHASE CHANGE OUT 


100 




ns 


tilol 


I/O OUT LOW TO SDOE LOW DATA 
BUS TRISTATE 





125 


ns 


tdtih 


DATA BUS TRISTATE TO SDIE HIGH 


-10 




ns 


tpcrh 


PHASE CHANGE OUT TO REQ OUT 
HIGH 


500 




ns 


trhah 


REQ OUT HIGH TO ACK IN HIGH 







ns 


tdvah 


DATA IN VALID TO ACK IN HIGH 







ns 


tahrl 


ACK IN HIGH TO REQ OUT LOW 





175 


ns 


tria- 


REQ OUT LOW TO DATA IN INVALID 







ns 


trial 


REQ OUT LOW TO ACK IN LOW 







ns 
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ACK IN LOW TO PHASE CHANGE OUT 
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9.2.10 Synchronous Information Transfer In 
(Initiator) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tdvrh 


DATA VALID IN TO REQ IN HIGH 







ns 


trhdi 


REQ IN HIGH TO DATA INVALID IN 


45 




ns 


trhrl 


REQ IN HIGH TO REQ IN LOW 


50 




ns 


trlrh 


REQ IN LOW TO REQ IN HIGH 


50 




ns 


tahal 


ACK OUT HIGH TO ACK OUT LOW 


1-1 5ns 




Tcyc 


talah 


ACK OUT LOW TO ACK OUT HIGH 


1-1 5ns 




Tcyc 


talpc 


ACK OUT LOW TO PHASE CHANGE IN 







ns 



PARAMETERS tslpc, tihol, tdtih, and tpcrh ALSO 
APPLY (see 9.2.6). 



NOTE: 

C/D* = C/D, MSG 
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FIGURE 9-23. SYNCHRONOUS INFORMATION TRANSFER IN(I)TIMING 
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9.2.11 Synchronous Information Transfer In 
(Target) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tdvrh 


DATA VALID OUT TO REQ OUT HIGH 


75 




ns 


trhdl 


REQ OUT HIGH TO DATA INVALID OUT 


115 




ns 


trhrl 


REQ OUT HIGH TO REQ OUT LOW 


1-1 5ns 




Tcyc 


trlrh 


REQ OUT LOW TO REQ OUT HIGH 


1-1 5ns 




Tcyc 


tahal 


ACK IN HIGH TO ACK IN LOW 


50 




ns 


talah 


ACK IN LOW TO ACK IN HIGH 


50 




ns 


talpc 


ACK IN LOW TO PHASE CHANGE OUT 







ns 



PARAMETERS tslpc, tihil, tiloh, and tpcrh ALSO 
APPLY (see 9.2.7). 



NOTE: 

C/D* = C/D, MSG 
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9.2.12 Synchronous Information Transfer Out 
(Initiator) 



SYMBOL 


CHARACTERISTIC 
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DATA VALID OUT TO ACK OUT HIGH 
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ns 
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ACK OUT HIGH TO DATA INVALID OUT 
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Tcyc 
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ACK OUT LOW TO ACK OUT HIGH 


1-1 5ns 




Tcyc 


talpc 


ACK OUT LOW TO PHASE CHANGE IN 







ns 



PARAMETERS tslpc, tiloh, tilil, and tpcrh ALSO 
APPLY (see 9.2.8). 



NOTE: 

C/D* = C/D, MSG 
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FIGURE 9-25. SYNCHRONOUS INFORMATION TRANSFER OUT(l)TIMING 
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9.2.13 Synchronous Information Transfer Out 
(Target) 
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CHARACTERISTIC 
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MAX 
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DATA VALID IN TO ACK IN HIGH 
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tahdi 


ACK IN HIGH TO DATA INVALID IN 
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PARAMETERS tslpc, tilol, tdtih, and tpcrh ALSO NOTE: 

APPLY (see 9.2.9). C/D* = C/D, MSG 
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9.2.14 Arbitration To Bus Free 
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9.2.15 Selection (Initiator) Or Reselection 
(Target) To Bus Free 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


ttadc 


TIMEOUT OR ABORT TO DATA BUS 
CLEARED* 







ns 


tdcsl 


DATA BUS CLEARED* TO SELO LOW 


200 




JLiS 


tslih 


SELO LOW TO SDIE HIGH, SDOE LOW 




8+1 20ns 


Tcyc 


tsldt 


SELO LOW TO DATA BUS TRISTATE 




8+1 20ns 


Tcyc 


tslgl 


SELO LOW TO gs LOW, cntl TRISTATE 




8+1 20ns 


Tcyc 



* SDx logic low, causing logic low on SCSI data 
bus. 



NOTE: 

gs = IGS (INITIATOR) or TGS (TARGET) 
cntl = ATN, ACK (INIT) or I/O, C/D, MSG, and 
REQ (TARGET) 










BSYI \ 




SELO 


\. 












/ 


SDx *v. 






|4 tslih ► 


SDIE / 








9° \ 












. \ 




/ 





FIGURE 9-28. SELECTION (I) OR RESELECTION (T) TO BUS FREE 
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9.2.16 Connected-as-an-lnitiator To Bus Free 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tbllh 


BSYI LOW TO SDIE HIGH, SDOE LOW 




8+1 20ns 


Tcyc 


tbldt 


BSYI LOW TO DATA BUS TRISTATE 




8+1 20ns 


Tcyc 


tblgl 


BSYI LOW TO IGS LOW, ATN TRISTATE 




8+1 20ns 


Tcyc 



NOTE: 

ATN* = ATN,ACK 



BYSI v 












SDx 


> 






4 thlih ^ 




SDOE 


\ 








bUlb 


/ 








^ iDigi f 


lUb \. 




ATN* > 









FIGURE 9-29. CONNECTED-AS AN-INITIATOR TO BUS FREE TIMING 
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9.2.17 Connected-as-a-Target To Bus Free 


SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tblih 


BSYO LOW TO SDIE HIGH, SDOE LOW 




8+1 20ns 


Tcyc 


tbldt 


BSYO LOW TO DATA BUS TRISTATE 




8+1 20ns 


Tcyc 


tblgl 


BSYO LOW TO TGS LOW, I/O TRISTATE 




8+1 20ns 


Tcyc 



NOTE: 

I/O* = I/O, C/D, MSG, REQ 




BYSO v 












SDx 


> 










SDOE 


\ 








SUIb 


/ 








1 iDigi t 


I US \^ 




I/O* > 









FIGURE 9-30. CONNECTED-AS-A-TARGET TO BUS FREE TIMING 
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